android jxl.jar 使用,使用jxl.jar在Android中操作Excel表格——重中之重——对隐藏表的处理...

曾简单了解过C#,将Excel(数据库表)表中的数据导入到C#中,使用C#制作的图形化界面进行对Excel表中数据进行操作。

今天想试试,在Android中导入Excel表格进行操作。在网上查阅资料,找到了jxl.jar包。

jxl.jar

jxl.jar是通过java操作excel表格的工具类库,是由java语言开发而成的。

本篇文章使用jxl.jar在Android中操作Excel表格实现四个功能

导入——将外部Excel表格导入到Android中(Android中的数据库中)。

导出——将在Android中的数据库中的Excel表格数据进行处理后,导出到手机的外部存储中

清空——清空在Android中的数据库中的Excel表格数据

查询——查询在Android中的数据库中的Excel表格数据

先看一下Demo案例效果图:

f6b8d03690d0?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Excel.gif

导入——将外部Excel表格导入到Android中(Android中的数据库中)。

先看一下Excel表格数据格式。

f6b8d03690d0?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Excel表格.png

导入数据——其实就是将Excel表格数据读出,然后存储到Android的数据库中。(不再原本的Excel表格上进行数据操作处理,而是导入到Android的数据库中,如果后面有需要,直接将数据库中的数据导出(为什么要导入到数据库中呢,因为一次性读完Excel表格数据后,直接写入到数据库中,Android对数据库中的数据的处理操作简单方便,而对Excel表格进行操作就需要使用jxl.jar包了。)。)。

先将jxl.jar包导入到项目中。

然后打开MainActivity.java进行编码

查看MainActivity.java中的代码——选择那张Excel表格,导入,导出,清空。

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

// Excel表格的表头

private String[] columnTitle = {"资产编号", "资产名称", "资产分类", "国标分类", "实有数量", "实有原值", "实有累计折旧", "盘点结果", "使用状况", "产品序列号",

"账面数量", "账面价值", "账面累计折旧", "账面净值", "取得方式", "规格型号", "计量单位", "取得日期", "财务入账日期", "价值类型", "存放地点", "使用部门", "使用人",

"原资产编号", "备注"};

private AppCompatButton btn_import;

private AppCompatButton btn_export;

private AppCompatButton btn_delete;

private AppCompatButton btn_query;

// 加载中的Dialog

private LoadingDialog mLoadingDialog;

private List mSchoolListToDb;

private List mDbToSchoolList;

private List mSchoolsExcelName;

private Set mHashSet;

private File mFileDir;

private Vector mSubFileVector;

// Spinner当前选中数据表

private File currentFile;

private AppCompatTextView select_text_db_file_excel;

private SlideFromBottomPopup mSlideFromBottomPopup;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initView();

initFileDir();

initData();

}

/**

* 创建特定文件夹以存放Excel表

*/

private void initFileDir() {

mFileDir = FileUtil.createDir("YunYangData");

}

/**

* 初始化数据库

*/

private void initData() {

mSchoolListToDb = new ArrayList<>();

mDbToSchoolList = new ArrayList<>();

LitePal.getDatabase();

mSchoolsExcelName = new ArrayList<>();

mHashSet = new HashSet<>();

mSubFileVector = new Vector();

mSlideFromBottomPopup =

new SlideFromBottomPopup(MainActivity.this, mFileDir.getAbsolutePath());

}

/**

* 初始化控件

*/

private void initView() {

btn_import = (AppCompatButton) findViewById(R.id.btn_import);

btn_export = (AppCompatButton) findViewById(R.id.btn_export);

btn_delete = (AppCompatButton) findViewById(R.id.btn_delete);

btn_query = (AppCompatButton) findViewById(R.id.btn_query);

btn_import.setOnClickListener(this);

btn_export.setOnClickListener(this);

btn_delete.setOnClickListener(this);

btn_query.setOnClickListener(this);

select_text_db_file_excel = (AppCompatTextView) findViewById(R.id.select_text_db_file_excel);

select_text_db_file_excel.setOnClickListener(this);

if (select_text_db_file_excel.getText().toString().equals("请您选择Excel文件")) {

checkFirstBtnEnabled(false);

}

}

private void checkBtnEnabled(boolean flag) {

btn_import.setEnabled(flag);

btn_export.setEnabled(flag);

btn_query.setEnabled(flag);

btn_delete.setEnabled(flag);

}

private void checkBtnEnabledFlag(boolean flag) {

btn_import.setEnabled(flag);

}

private void checkFirstBtnEnabled(boolean flag) {

btn_import.setEnabled(flag);

btn_export.setEnabled(flag);

btn_query.setEnabled(flag);

btn_delete.setEnabled(flag);

}

private List shenqi;

@Override

public void onClick(View v) {

switch (v.getId()) {

case R.id.btn_import:

checkCurrentFileNameFromDb();

break;

case R.id.btn_export:

mLoadingDialog = new LoadingDialog(this, "数据正在导出中...");

startLoading();

exportCreateExcelFromJxl();

break;

case R.id.btn_delete:

if (currentFile != null) {

deleteDbFromDataSheet(true);

} else {

Toast.makeText(this, "请选中要从本地数据库中删除之前导入的Excel文件名称", Toast.LENGTH_LONG).show();

}

break;

case R.id.btn_query:

Intent intentQueryData = new Intent(MainActivity.this, QueryDataActivity.class);

startActivity(intentQueryData);

break;

case R.id.select_text_db_file_excel:

mSlideFromBottomPopup.newPopupBottomShow();

break;

default:

break;

}

}

/**

* 检查数据库中是否存在当前Excel表名,如果存在,导入时是否覆盖导入。

*/

private void checkCurrentFileNameFromDb() {

new AsyncTask() {

@Override

protected Integer doInBackground(Void... voids) {

final int count = LitePal

.where("ownershipDataSheet = ?", currentFile.getName())

.count(School.class);

return count;

}

@Override

protected void onPostExecute(Integer aVoid) {

super.onPostExecute(aVoid);

mLoadingDialog = new LoadingDialog(MainActivity.this, "数据正在导入中...");

if (aVoid > 0) {

new QMUIDialog.MessageDialogBuilder(MainActivity.this)

.setTitle("提示")

.setMessage("本地数据库中已经存在 "

+ StrUtil.getFileNameNoEx(currentFile.getName())

+ " Excel表,是否覆盖导入?")

.addAction("取消", new QMUIDialogAction.ActionListener() {

@Override

public void onClick(QMUIDialog dialog, int index) {

dialog.dismiss();

}

})

.addAction("确定", new QMUIDialogAction.ActionListener() {

@Override

public void onClick(QMUIDialog dialog, int index) {

if (currentFile != null) {

deleteDbFromDataSheet(false);

readExcelToDB();

} else {

Toast.makeText(MainActivity.this, "请选中要从本地数据库中覆盖之前导入的Excel文件名称", Toast.LENGTH_LONG).show();

}

dialog.dismiss();

}

})

.show();

} else {

readExcelToDB();

}

}

}.execute();

}

/**

* 依据 所属数据表 列进行数据删除

*/

private void deleteDbFromDataSheet(final boolean flag) {

startLoading();

new AsyncTask() {

@Override

protected Integer doInBackground(Void... params) {

try {

LitePal

.deleteAll(

School.class, "ownershipDataSheet = ?",

currentFile.getName());

return 1;

} catch (Exception e) {

e.printStackTrace();

return 0;

}

}

@Override

protected void onPostExecute(Integer aVoid) {

super.onPostExecute(aVoid);

if (aVoid == 1) {

if (flag) {

Toast.makeText(MainActivity.this, "从本地数据库中删除 " + currentFile.getName() + " 成功", Toast.LENGTH_LONG).show();

}

} else {

if (flag) {

stopLoading();

Toast.makeText(MainActivity.this, "从本地数据库中删除 " + currentFile.getName() + " 失败", Toast.LENGTH_LONG).show();

}

}

stopLoading();

}

}.execute();

}

/**

* 导出 创建Excel表格,使用Jxl

*/

private void exportCreateExcelFromJxl() {

new AsyncTask() {

@Override

protected Integer doInBackground(String... params) {

try {

// 创建Excel表格

ExcelUtils

.initExcel(FileUtil

.createFile(currentFile.getName())

.getAbsolutePath(), columnTitle);

// 创建Sheet表,并写入数据

mDbToSchoolList.clear();

/*

导出之前,删除原表,创建新表

编写导出LitePal语句,导出Excel表格依据26列(所属数据表进行导出)

*/

mDbToSchoolList = LitePal.findAll(School.class);

ExcelUtils.writeSchoolListToExcel(mDbToSchoolList, FileUtil

.createFile(currentFile.getName())

.getAbsolutePath(), MainActivity.this);

return 1;

} catch (Exception e) {

e.printStackTrace();

return 0;

}

}

@Override

protected void onPostExecute(Integer aVoid) {

super.onPostExecute(aVoid);

if (aVoid == 1) {

Toast.makeText(MainActivity.this, "导出成功!", Toast.LENGTH_LONG).show();

} else {

Toast.makeText(MainActivity.this, "导出失败!", Toast.LENGTH_LONG).show();

}

stopLoading();

}

}.execute();

}

/**

* 结束加载Dialog

*/

private void stopLoading() {

if (mLoadingDialog != null && mLoadingDialog.isShowing()) {

mLoadingDialog.dismiss();

}

}

/**

* 开始加载Dialog

*/

private void startLoading() {

if (mLoadingDialog != null && !mLoadingDialog.isShowing()) {

mLoadingDialog.show();

}

}

@Override

public void onStart() {

super.onStart();

EventBus.getDefault().register(this);

}

@Override

protected void onStop() {

super.onStop();

EventBus.getDefault().unregister(this);

stopLoading();

}

/**

* 读取excel数据到数据库里(LitePal)

*/

private void readExcelToDB() {

startLoading();

new Thread(new Runnable() {

@Override

public void run() {

try {

/*

Android 读取Assets 下的Excel文件

*/

// InputStream is = context.getAssets().open("康复所.xls");

// Workbook book = Workbook.getWorkbook(is);

Workbook book = Workbook.getWorkbook(currentFile);

// 获取表页数

final int bookPage = book.getNumberOfSheets();

Log.e("bookPage", "bookPage = " + bookPage);

// 获得第一个工作表对象

Sheet sheet = book.getSheet(0);

int Rows = sheet.getRows();

School schoolData = null;

for (int i = 1; i < Rows; ++i) {

String assetNumber = (sheet.getCell(0, i)).getContents();

String assetName = (sheet.getCell(1, i)).getContents();

String assetClassification = (sheet.getCell(2, i)).getContents();

String nationalStandardClassification = (sheet.getCell(3, i)).getContents();

String actualNumberOf = (sheet.getCell(4, i)).getContents();

String actualValue = (sheet.getCell(5, i)).getContents();

String actualAccumulatedDepreciation = (sheet.getCell(6, i)).getContents();

String inventoryResults = (sheet.getCell(7, i)).getContents();

String useStatus = (sheet.getCell(8, i)).getContents();

String serialNumber = (sheet.getCell(9, i)).getContents();

String physicalCountQuantity = (sheet.getCell(10, i)).getContents();

String bookValue = (sheet.getCell(11, i)).getContents();

String bookDepreciation = (sheet.getCell(12, i)).getContents();

String netBookValue = (sheet.getCell(13, i)).getContents();

String gainingMethod = (sheet.getCell(14, i)).getContents();

String specificationsAndModels = (sheet.getCell(15, i)).getContents();

String unitOfMeasurement = (sheet.getCell(16, i)).getContents();

String dateOfAcquisition = (sheet.getCell(17, i)).getContents();

String dateOfFinancialEntry = (sheet.getCell(18, i)).getContents();

String typeOfValue = (sheet.getCell(19, i)).getContents();

String storagePlace = (sheet.getCell(20, i)).getContents();

String userDepartment = (sheet.getCell(21, i)).getContents();

String user = (sheet.getCell(22, i)).getContents();

String originalAssetNumber = (sheet.getCell(23, i)).getContents();

String remark = (sheet.getCell(24, i)).getContents();

/*

25是盘点数量

导入的时候把实有数量给盘点数量

导出的时候把盘点数量给实有数量

*/

// 导入Db——这里先直接赋值为0

String inventoryData = "0";

// 26是所属数据表

// String ownershipDataSheet = "康复所";

String ownershipDataSheet = "";

if (currentFile != null) {

ownershipDataSheet = currentFile.getName();

}

schoolData = new School(assetNumber, assetName, assetClassification,

nationalStandardClassification, actualNumberOf, actualValue,

actualAccumulatedDepreciation, inventoryResults, useStatus,

serialNumber, physicalCountQuantity, bookValue,

bookDepreciation, netBookValue, gainingMethod, specificationsAndModels,

unitOfMeasurement, dateOfAcquisition, dateOfFinancialEntry,

typeOfValue, storagePlace, userDepartment, user, originalAssetNumber

, remark, inventoryData, ownershipDataSheet);

mSchoolListToDb.add(schoolData);

}

book.close();

saveDB();

runOnUiThread(new Runnable() {

@Override

public void run() {

stopLoading();

checkBtnEnabled(true);

Toast.makeText(MainActivity.this, "导入成功", Toast.LENGTH_SHORT).show();

}

});

} catch (Exception e) {

runOnUiThread(new Runnable() {

@Override

public void run() {

stopLoading();

Toast.makeText(MainActivity.this, "导入失败", Toast.LENGTH_SHORT).show();

}

});

}

}

}).start();

}

/**

* 数据保存到数据库中并且去空行

*/

private void saveDB() {

if (mSchoolListToDb != null) {

LitePal.saveAll(mSchoolListToDb);

// 去空行

LitePal.deleteAll(School.class, "assetNumber = ?", "");

}

}

@Subscribe(threadMode = ThreadMode.MAIN)

public void onMessageEvent(ExpandMessage expandMessage) {

final String fileName = expandMessage.getFileName();

select_text_db_file_excel.setText(fileName);

if (!select_text_db_file_excel.getText().toString().equals("请您选择Excel文件")) {

checkBtnEnabledFlag(true);

}

EventBus

.getDefault()

.postSticky(new CurrentFileName(fileName));

for (File file :

expandMessage.getSubFileVector()) {

if (file.getName().equals(fileName)) {

currentFile = file;

}

}

}

@Subscribe(threadMode = ThreadMode.MAIN)

public void onFileListsEvent(UnderWayFileLists fileLists) {

for (String str :

fileLists.getSetFiles()) {

if (!str.equals(fileLists.getFileName())) {

checkBtnEnabled(false);

checkBtnEnabledFlag(true);

} else {

checkBtnEnabled(true);

return;

}

}

}

}

代码功能,注释写的很清楚。

数据库使用的库为 LitePal 。

创建Excel表格,使用了 ZzExcelCreator Excel表格生成工具,该库本质上也是使用jxl.jar

导入——需要注意的是jxl.jar读写数据格式都是字符型数据。

/**

* 读取excel数据到数据库里(LitePal)

*/

private void readExcelToDB() {

startLoading();

new Thread(new Runnable() {

@Override

public void run() {

try {

/*

Android 读取Assets 下的Excel文件

*/

// InputStream is = context.getAssets().open("康复所.xls");

// Workbook book = Workbook.getWorkbook(is);

Workbook book = Workbook.getWorkbook(currentFile);

// 获取表页数

final int bookPage = book.getNumberOfSheets();

Log.e("bookPage", "bookPage = " + bookPage);

// 获得第一个工作表对象

Sheet sheet = book.getSheet(0);

int Rows = sheet.getRows();

School schoolData = null;

for (int i = 1; i < Rows; ++i) {

String assetNumber = (sheet.getCell(0, i)).getContents();

String assetName = (sheet.getCell(1, i)).getContents();

String assetClassification = (sheet.getCell(2, i)).getContents();

String nationalStandardClassification = (sheet.getCell(3, i)).getContents();

String actualNumberOf = (sheet.getCell(4, i)).getContents();

String actualValue = (sheet.getCell(5, i)).getContents();

String actualAccumulatedDepreciation = (sheet.getCell(6, i)).getContents();

String inventoryResults = (sheet.getCell(7, i)).getContents();

String useStatus = (sheet.getCell(8, i)).getContents();

String serialNumber = (sheet.getCell(9, i)).getContents();

String physicalCountQuantity = (sheet.getCell(10, i)).getContents();

String bookValue = (sheet.getCell(11, i)).getContents();

String bookDepreciation = (sheet.getCell(12, i)).getContents();

String netBookValue = (sheet.getCell(13, i)).getContents();

String gainingMethod = (sheet.getCell(14, i)).getContents();

String specificationsAndModels = (sheet.getCell(15, i)).getContents();

String unitOfMeasurement = (sheet.getCell(16, i)).getContents();

String dateOfAcquisition = (sheet.getCell(17, i)).getContents();

String dateOfFinancialEntry = (sheet.getCell(18, i)).getContents();

String typeOfValue = (sheet.getCell(19, i)).getContents();

String storagePlace = (sheet.getCell(20, i)).getContents();

String userDepartment = (sheet.getCell(21, i)).getContents();

String user = (sheet.getCell(22, i)).getContents();

String originalAssetNumber = (sheet.getCell(23, i)).getContents();

String remark = (sheet.getCell(24, i)).getContents();

/*

25是盘点数量

导入的时候把实有数量给盘点数量

导出的时候把盘点数量给实有数量

*/

// 导入Db——这里先直接赋值为0

String inventoryData = "0";

// 26是所属数据表

// String ownershipDataSheet = "康复所";

String ownershipDataSheet = "";

if (currentFile != null) {

ownershipDataSheet = currentFile.getName();

}

schoolData = new School(assetNumber, assetName, assetClassification,

nationalStandardClassification, actualNumberOf, actualValue,

actualAccumulatedDepreciation, inventoryResults, useStatus,

serialNumber, physicalCountQuantity, bookValue,

bookDepreciation, netBookValue, gainingMethod, specificationsAndModels,

unitOfMeasurement, dateOfAcquisition, dateOfFinancialEntry,

typeOfValue, storagePlace, userDepartment, user, originalAssetNumber

, remark, inventoryData, ownershipDataSheet);

mSchoolListToDb.add(schoolData);

}

book.close();

saveDB();

runOnUiThread(new Runnable() {

@Override

public void run() {

stopLoading();

checkBtnEnabled(true);

Toast.makeText(MainActivity.this, "导入成功", Toast.LENGTH_SHORT).show();

}

});

} catch (Exception e) {

runOnUiThread(new Runnable() {

@Override

public void run() {

stopLoading();

Toast.makeText(MainActivity.this, "导入失败", Toast.LENGTH_SHORT).show();

}

});

}

}

}).start();

}

导出——创建新的Excel表格,将数据库中的数据按照导入时的数据格式导出到刚创建的新的Excel表格中。

/**

* 导出 创建Excel表格,使用Jxl

*/

private void exportCreateExcelFromJxl() {

new AsyncTask() {

@Override

protected Integer doInBackground(String... params) {

try {

// 创建Excel表格

ExcelUtils

.initExcel(FileUtil

.createFile(currentFile.getName())

.getAbsolutePath(), columnTitle);

// 创建Sheet表,并写入数据

mDbToSchoolList.clear();

/*

导出之前,删除原表,创建新表

编写导出LitePal语句,导出Excel表格依据26列(所属数据表进行导出)

*/

mDbToSchoolList = LitePal.findAll(School.class);

ExcelUtils.writeSchoolListToExcel(mDbToSchoolList, FileUtil

.createFile(currentFile.getName())

.getAbsolutePath(), MainActivity.this);

return 1;

} catch (Exception e) {

e.printStackTrace();

return 0;

}

}

@Override

protected void onPostExecute(Integer aVoid) {

super.onPostExecute(aVoid);

if (aVoid == 1) {

Toast.makeText(MainActivity.this, "导出成功!", Toast.LENGTH_LONG).show();

} else {

Toast.makeText(MainActivity.this, "导出失败!", Toast.LENGTH_LONG).show();

}

stopLoading();

}

}.execute();

}

ExcelUtils.writeSchoolListToExcel()方法

public static void writeSchoolListToExcel(List objList,

String filePath, Context c) {

if (objList != null && objList.size() > 0) {

final int countDb = objList.size();

WritableWorkbook writebook = null;

InputStream in = null;

try {

WorkbookSettings setEncode = new WorkbookSettings();

setEncode.setEncoding(UTF8_ENCODING);

in = new FileInputStream(new File(filePath));

Workbook workbook = Workbook.getWorkbook(in);

writebook = Workbook.createWorkbook(new File(filePath),

workbook);

//WritableSheet sheet = writebook.createSheet("页签1", 0);

WritableSheet sheet = writebook.getSheet(0);

for (int j = 1; j < countDb; j++) {

School school = objList.get(j);

String actualNumberOf = school.getActualNumberOf();

String physicalCountQuantity = school.getPhysicalCountQuantity();

// String数据类型转换为int数据类型,取掉小数点|判空操作

actualNumberOf = StrUtil.isNullOrEmptyAndSub(actualNumberOf);

physicalCountQuantity = StrUtil.isNullOrEmptyAndSub(physicalCountQuantity);

sheet.addCell(new Label(0, j + 1, school.getAssetNumber(), arial10formatnobg));

sheet.addCell(new Label(1, j + 1, school.getAssetName(), arial10formatnobg));

sheet.addCell(new Label(2, j + 1, school.getAssetClassification(), arial10formatnobg));

sheet.addCell(new Label(3, j + 1, school.getNationalStandardClassification(), arial10formatnobg));

sheet.addCell(new Label(4, j + 1, actualNumberOf, arial10formatnobg));

sheet.addCell(new Label(5, j + 1, school.getActualValue(), arial10formatnobg));

sheet.addCell(new Label(6, j + 1, school.getActualAccumulatedDepreciation(), arial10formatnobg));

int tp = Integer.parseInt(physicalCountQuantity) - Integer.parseInt(actualNumberOf);

if (tp == 0) {

sheet.addCell(new Label(7, j + 1, "无盈亏", arial10formatnobg));

} else if (tp > 0) {

sheet.addCell(new Label(7, j + 1, "盘亏", arial10formatnobg));

} else if (tp < 0) {

sheet.addCell(new Label(7, j + 1, "盘盈", arial10formatnobg));

}

sheet.addCell(new Label(8, j + 1, school.getUseStatus(), arial10formatnobg));

sheet.addCell(new Label(9, j + 1, school.getSerialNumber(), arial10formatnobg));

sheet.addCell(new Label(10, j + 1, physicalCountQuantity, arial10formatnobg));

sheet.addCell(new Label(11, j + 1, school.getBookValue(), arial10formatnobg));

sheet.addCell(new Label(12, j + 1, school.getBookDepreciation(), arial10formatnobg));

sheet.addCell(new Label(13, j + 1, school.getNetBookValue(), arial10formatnobg));

sheet.addCell(new Label(14, j + 1, school.getGainingMethod(), arial10formatnobg));

sheet.addCell(new Label(15, j + 1, school.getSpecificationsAndModels(), arial10formatnobg));

sheet.addCell(new Label(16, j + 1, school.getUnitOfMeasurement(), arial10formatnobg));

sheet.addCell(new Label(17, j + 1, school.getDateOfAcquisition(), arial10formatnobg));

sheet.addCell(new Label(18, j + 1, school.getDateOfFinancialEntry(), arial10formatnobg));

sheet.addCell(new Label(19, j + 1, school.getTypeOfValue(), arial10formatnobg));

sheet.addCell(new Label(20, j + 1, school.getStoragePlace(), arial10formatnobg));

sheet.addCell(new Label(21, j + 1, school.getUserDepartment(), arial10formatnobg));

sheet.addCell(new Label(22, j + 1, school.getUser(), arial10formatnobg));

sheet.addCell(new Label(23, j + 1, school.getOriginalAssetNumber(), arial10formatnobg));

sheet.addCell(new Label(24, j + 1, school.getRemark(), arial10formatnobg));

}

// 一般的Excel表格都是有填写说明的

WritableSheet sheet3 = writebook.createSheet("填写说明", 2);

sheet3.addCell(new Label(0, 0, "这是填写说明的表", arial10formatnobg));

writebook.write();

Log.e("writeObjListToExcel", "有需要导出的数据! ");

} catch (Exception e) {

Log.e("writeObjListToExcel", "进来创建catch" + e.getMessage());

e.printStackTrace();

} finally {

if (writebook != null) {

try {

writebook.close();

} catch (Exception e) {

e.printStackTrace();

}

}

if (in != null) {

try {

in.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

} else {

Log.e("writeSchoolListToExcel", "没有有需要导出的数据! ");

}

}

从数据库导出数据到外部的Excel时,需要注意两点

(一)填写说明这个sheet表

(二)隐藏表——表是隐藏的,一般都是表回到大系统的时候会有这个。不能忽略,如果忽略,那么表回归大系统的时候就会报错。

如何查看隐藏表:

f6b8d03690d0?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

hide.png

点击鼠标左键取消隐藏后,选择需要显示的sheet表以及查看有多少张被隐藏的表。

f6b8d03690d0?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

hidetwo.png

我们可以清楚的看到hidesheet表被隐藏了。那么我们在导出时,也需要创建和hidesheet表一模一样的表。然后导出。

在ExcelUtils.writeSchoolListToExcel()方法中加上

/*

隐藏表

表是隐藏的,一般都是表回到大系统的时候会有这个。

不能忽略,如果忽略,那么表回归大系统的时候就会报错。

*/

// 隐藏表

sheet2.setHidden(true);

sheet2.addCell(new Label(0, 0, "这是隐藏的表", arial10formatnobg));

// 一般的Excel表格都是有填写说明的

WritableSheet sheet3 = writebook.createSheet("填写说明", 2);

sheet3.addCell(new Label(0, 0, "这是填写说明的表", arial10formatnobg));

这样之后表回归大系统进行统一查看的时候,就不会报错了。

清空——可以根据需求清空某些数据,这里按照所属数据表进行数据清空。

/**

* 依据 所属数据表 列进行数据删除

*/

private void deleteDbFromDataSheet(final boolean flag) {

startLoading();

new AsyncTask() {

@Override

protected Integer doInBackground(Void... params) {

try {

LitePal

.deleteAll(

School.class, "ownershipDataSheet = ?",

currentFile.getName());

return 1;

} catch (Exception e) {

e.printStackTrace();

return 0;

}

}

@Override

protected void onPostExecute(Integer aVoid) {

super.onPostExecute(aVoid);

if (aVoid == 1) {

if (flag) {

Toast.makeText(MainActivity.this, "从本地数据库中删除 " + currentFile.getName() + " 成功", Toast.LENGTH_LONG).show();

}

} else {

if (flag) {

stopLoading();

Toast.makeText(MainActivity.this, "从本地数据库中删除 " + currentFile.getName() + " 失败", Toast.LENGTH_LONG).show();

}

}

stopLoading();

}

}.execute();

}

导出后的文件放在外部存储外面(导入的Excel文件放在YunYangData文件夹下)。

f6b8d03690d0?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

导出.png

查询——QueryDataActivity.java,按照全部,盘亏,无盈亏三个Tab进行分类。

public class QueryDataActivity extends AppCompatActivity {

private static final String POSITION = "POSITION";

private QueryDataAdapter mSectionsPagerAdapter;

private ViewPager mViewPager;

private TabLayout mTabLayout;

private List mFragments;

private String[] mTitles;

private int[] mInts;

private String ownershipDataSheetName;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_query_data);

EventBus.getDefault().register(this);

initView();

initData();

}

private void initData() {

findDbLitePal();

}

/**

* 根据inventoryResults(盘点结果)去数据库中查找对应数据

*/

private void findDbLitePal() {

new AsyncTask() {

@Override

protected Integer doInBackground(String... params) {

try {

if (LitePal.count(School.class) <= 0) {

Log.e("Excel", "LitePal数据库中无数据");

mTitles[0] = "全部";

mTitles[1] = "盘亏";

mTitles[2] = "无盈亏";

return 0;

} else {

// 全部

final int count = LitePal

.where("ownershipDataSheet = ?", ownershipDataSheetName)

.count(School.class);

// 减去行1

mInts[0] = count - 1;

// 盘亏

mInts[1] = LitePal

.where("inventoryResults = ? and ownershipDataSheet = ?", "盘亏", ownershipDataSheetName)

.count(School.class);

// 无盈亏

mInts[2] = LitePal

.where("inventoryResults = ? and ownershipDataSheet = ?", "无盈亏", ownershipDataSheetName)

.count(School.class);

mTitles[0] = "全部(" + mInts[0] + ")";

mTitles[1] = "盘亏(" + mInts[1] + ")";

mTitles[2] = "无盈亏(" + mInts[2] + ")";

return 1;

}

} catch (Exception e) {

e.printStackTrace();

mTitles[0] = "全部";

mTitles[1] = "盘亏";

mTitles[2] = "无盈亏";

return 0;

}

}

@Override

protected void onPostExecute(Integer aVoid) {

super.onPostExecute(aVoid);

mFragments.add(FragmentDish.newInstance(0));

mFragments.add(FragmentDish.newInstance(1));

mFragments.add(FragmentDish.newInstance(2));

if (mFragments.size() > 0 && mTitles.length > 0) {

mSectionsPagerAdapter = new QueryDataAdapter(getSupportFragmentManager(), mFragments, mTitles);

mViewPager.setAdapter(mSectionsPagerAdapter);

mViewPager.setOffscreenPageLimit(3);

mTabLayout.setupWithViewPager(mViewPager);

setupTabLayout(mTabLayout);

}

}

}.execute();

}

private void setupTabLayout(TabLayout tabLayout) {

tabLayout.setTabMode(TabLayout.MODE_FIXED);

tabLayout.setTabGravity(TabLayout.GRAVITY_FILL);

tabLayout.setupWithViewPager(mViewPager);

}

private void initView() {

mViewPager = (ViewPager) findViewById(R.id.container);

mTabLayout = (TabLayout) findViewById(R.id.tabs);

mFragments = new ArrayList<>();

mTitles = new String[3];

mInts = new int[3];

}

@Override

public void onSaveInstanceState(Bundle outState) {

super.onSaveInstanceState(outState);

outState.putInt(POSITION, mTabLayout.getSelectedTabPosition());

}

@Override

protected void onRestoreInstanceState(Bundle savedInstanceState) {

super.onRestoreInstanceState(savedInstanceState);

mViewPager.setCurrentItem(savedInstanceState.getInt(POSITION));

}

@Override

protected void onDestroy() {

super.onDestroy();

EventBus.getDefault().unregister(this);

}

@Subscribe(threadMode = ThreadMode.MAIN, sticky = true)

public void onCurrentFileNameEvent(CurrentFileName currentFile) {

ownershipDataSheetName = currentFile.getFileName();

}

}

QueryDataActivity.java中三个Tab——FragmentDish.java

/**

* 作者 yunyang

* 时间 2019/1/7 9:38

* 文件 DataConversion

* 描述 盘的碎片(全部——盘亏——无盈盘)

*/

public class FragmentDish extends Fragment {

private RecyclerView mRecyclerView;

private DishFragmentAdapter mFragmentDishAdapter;

private LoadingDialog mLoadingDialog;

private List mDbToSchoolList;

private String ownershipDataSheetName;

public static Fragment newInstance(int tab) {

Bundle bundle = new Bundle();

FragmentDish fragmentWin = new FragmentDish();

bundle.putInt("tab", tab);

fragmentWin.setArguments(bundle);

return fragmentWin;

}

@Nullable

@Override

public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {

View view = inflater.inflate(R.layout.fragment_dish, container, false);

initView(view);

return view;

}

private void initView(View view) {

initRecy(view);

Bundle bundle = getArguments();

if (bundle != null) {

final int tab = bundle.getInt("tab");

switch (tab) {

case 0:

// 全部

findDbLitePal("全部");

break;

case 1:

// 盘亏

findDbLitePal("盘亏");

break;

case 2:

// 无盈亏

findDbLitePal("无盈亏");

break;

default:

break;

}

}

}

private void initRecy(View view) {

mRecyclerView = (RecyclerView) view.findViewById(R.id.query_fragment_recy_dish);

mDbToSchoolList = new ArrayList<>();

mLoadingDialog = new LoadingDialog(getActivity(), "数据正在加载中...");

mFragmentDishAdapter = new DishFragmentAdapter(getActivity(), mDbToSchoolList);

LinearLayoutManager manager = new LinearLayoutManager(getActivity());

mRecyclerView.setLayoutManager(manager);

mRecyclerView.setAdapter(mFragmentDishAdapter);

}

/**

* 结束加载Dialog

*/

private void stopLoading() {

if (mLoadingDialog != null && mLoadingDialog.isShowing()) {

mLoadingDialog.dismiss();

}

}

/**

* 开始加载Dialog

*/

private void startLoading() {

if (mLoadingDialog != null && !mLoadingDialog.isShowing()) {

mLoadingDialog.show();

}

}

/**

* 根据inventoryResults(盘点结果)去数据库中查找对应数据

*

* @param string

*/

private void findDbLitePal(String string) {

startLoading();

new AsyncTask() {

@Override

protected Integer doInBackground(String... params) {

try {

mDbToSchoolList.clear();

if (!StrUtil.isEmpty(ownershipDataSheetName)) {

final int countDb = LitePal.count(School.class);

if (countDb > 0) {

if (params[0].equals("全部")) {

mDbToSchoolList = LitePal

.where("ownershipDataSheet = ?", ownershipDataSheetName)

.find(School.class);

mDbToSchoolList.remove(0);

} else {

mDbToSchoolList = LitePal

.where(

"ownershipDataSheet = ? and inventoryResults = ?",

ownershipDataSheetName, params[0])

.find(School.class);

}

return 1;

}

}

return 0;

} catch (Exception e) {

e.printStackTrace();

return 0;

}

}

@Override

protected void onPostExecute(Integer aVoid) {

super.onPostExecute(aVoid);

if (aVoid == 1) {

if (mFragmentDishAdapter != null) {

mFragmentDishAdapter.setDataNotify(mDbToSchoolList);

}

} else {

}

stopLoading();

}

}.execute(string);

}

@Override

public void onCreate(@Nullable Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

EventBus.getDefault().register(this);

}

@Override

public void onDestroy() {

super.onDestroy();

EventBus.getDefault().unregister(this);

}

@Subscribe(threadMode = ThreadMode.MAIN, sticky = true)

public void onCurrentFileNameEvent(CurrentFileName currentFile) {

ownershipDataSheetName = currentFile.getFileName();

}

}

查询页面就是查找数据库中的数据,然后进行数据集显示到RecyclerView的Item上。

f6b8d03690d0?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

ExcelQuery.gif

使用此案例,当App安装到手机上,就会在外部存储中创建YunYangData文件夹,然后可以把固定的文件格式的Excel文件放入其中。使用App进行处理。(也可以先创建YunYangData文件夹,然后把固定的文件格式的Excel文件放入其中,打开App进行操作)。

此Demo代码下载

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/468088.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自定义协议的这些典型例子你会了吗?

上次分享的《分享一个很酷的上位机软件》中&#xff0c;有如下协议&#xff1a;有位读者朋友问数据为什么要按这样的格式来发。其实这是个自定义协议&#xff0c;这是上位机开发者定义的一个数据交互协议。我们下位机往伏特加上位机发送数据需要遵循这样的协议数据&#xff0c;…

java 原子类_小学妹教你并发编程的三大特性:原子性、可见性、有序性

在并发编程中有三个非常重要的特性&#xff1a;原子性、有序性,、可见性&#xff0c;学妹发现你对它们不是很了解&#xff0c;她很着急&#xff0c;因为理解这三个特性对于能够正确地开发高并发程序有很大的帮助&#xff0c;接下来的面试中也极有可能被问到&#xff0c;小学妹就…

关于a标签不能调用js方法的小细节,你注意到了么?

在我们做后台删除的时候&#xff0c;当点击删除标签时&#xff0c;你希望弹出一个友好的提示框&#xff01;比如这样&#xff1a; 那代码应该怎样写呢&#xff1f;向下面这样&#xff1f; <!DOCTYPE html> <html lang"en"> <head><meta charset…

4岁小女孩给Linux内核贡献提交

今天在reddit上看到一个有趣的讨论&#xff0c;一个4岁的小女孩给Linux提交了一个补丁&#xff0c;并且这个补丁合并到了代码中。链接如下&#xff1a;https://www.reddit.com/r/linux/comments/2pqqla/kernel_commit_4_year_old_girl_fixes_formatting_to/cmzfvpl/我们看看她修…

php文件上传后没有打开权限_记墨者靶机文件上传(二)

“ 声明&#xff1a;该公众号大部分文章来自日常学习笔记&#xff0c;若是转载会先得到原作者授权或其他公众号白名单&#xff0c;并附上链接。剑者&#xff0c;心之刃也。既可为杀&#xff0c;亦可为护。杀与护&#xff0c;不过一念之间&#xff01;请勿利用文章内的相关技术从…

你还会写这段C51程序吗?

经典题目解析定时器T1采用计数模式&#xff0c;方式1中断&#xff0c;计数输入引脚 P3.5外接开关按钮作为计数信号输入&#xff0c;P1口控制8个LED小灯&#xff0c;初始状态所有小灯全亮&#xff0c;按3次按钮开关产生计数中断时&#xff0c;高3位和低5位交替闪烁3次&#xff0…

JDBC连接数据库(Java DataBase Connectivity,java)

通过JDBC操作数据库(以mysql为例) 1、官网下载JDBC的相关JAR包 【https://dev.mysql.com/downloads/connector/j/】 2、解压后&#xff0c;导入jar包 连接数据(引入外部jar包)项目上右键->build path->configure build path->上面Libraries->Add External JARs 3、…

过年回家抢票攻略

每年过年抢票都是一个困难的事情&#xff0c;所以决定发一篇文章汇总一下各种抢票软件&#xff0c;大家自己有方案的可以在文章后面留言&#xff0c;让跟多的人看到&#xff0c;希望大家都能顺利抢到车票&#xff0c;顺利回家。超级抢票机&#xff0c;一款超强的火车票抢票神器…

C语言,函数不可返回指向栈内存的指针

预备知识&#xff1a;内存的分类C/C程序占用的内存分为两大类&#xff1a;静态存储区与动态存储区。其示意图如下所示&#xff1a;数据保存在静态存储区与动态存储区的区别就是&#xff1a;静态存储区在编译-链接阶段已经确定了&#xff0c;程序运行过程中不会变化&#xff0c;…

android 界面绘制完毕,几种获取android 界面性能数据的快捷方法

探测 界面绘制性能获取界面的绘制性能有很多种方法&#xff0c;比如说 Systrace 但是这种方法 有一个不太好的地方就是使用起来较为复杂&#xff0c; 有没有一种 谷歌官方推荐 的方便一点的方法 &#xff0c;其实是有的&#xff0c;只需要一个函数 就可以获得layout的时间 非常…

联想rd650怎么装系统win7_Lenovo g50重装win7系统|U盘重装联想g50笔记本系统

Lenovo可以说是个家喻户晓的品牌很多小伙伴们也是使用联想的电脑&#xff0c;今天有小伙伴和小编提了一款Lenovo g50笔记本&#xff0c;小编了解到这款笔记本电脑的口碑和销量都很不错&#xff0c;其实这位小伙伴的问题呢是要如何重装win7系统&#xff0c;毕竟质量再好的电脑也…

书籍推荐

今天天气很好&#xff0c;风和日丽&#xff0c;艳阳高照&#xff0c;大家心情应该也很不错&#xff0c;毕竟&#xff0c;今天是周五&#xff0c;就像上学的时候一样&#xff0c;下午的铃声一响&#xff0c;每个同学都像脱缰的野马一样&#xff0c;周五&#xff0c;上班族的人们…

【转】JMeter学习(十三)分布式部署

Jmeter 是Java 应用&#xff0c;对于CPU和内存的消耗比较大&#xff0c;因此&#xff0c;当需要模拟数以千计的并发用户时&#xff0c;使用单台机器模拟所有的并发用户就有些力不从心&#xff0c;甚至会引起JAVA内存溢出错误。为了让jmeter工具提供更大的负载能力&#xff0c;j…

android mvp框架基类,Android MVP架构模式基类封装

前言MVP模式是Android官方推荐的架构模式&#xff0c;可使视图与数据层完全解耦。本文旨意封装在MVP模式中的基类如Activity&#xff0c;Fragment&#xff0c;Presenter类。以下内容建议在了解了mvp模式的读者阅读&#xff0c;如果还有对mvp架构模式有疑问的&#xff0c;请看我…

C语言,字符串指针做函数参数

看一下下面这段代码有什么问题&#xff1f;#include "stdio.h" //#include "stdbool.h" #include "string.h" #include "stdlib.h" #include "math.h"void getMemory(char *p) {/*char *p str*/p (char *)malloc(100);str…

java创建一个未知长度的数组_Java数组的创建操作

数组是一个固定长度的&#xff0c;包含了相同类型数据的 容器步骤1:声明数组步骤2:创建数组步骤3:访问数组步骤4:数组长度步骤5:练习-数组最小值步骤6:答案-数组最小值步骤 1 : 声明数组int[] a; 声明了一个数组变量。[]表示该变量是一个数组int 表示数组里的每一个元素都是一个…

Linux内核中的GPIO系统

一、前言作为一个工作多年的系统工程师&#xff0c;免不了做两件事情&#xff1a;培训新员工和给新员工分配任务。对于那些刚刚从学校出来的学生&#xff0c;一般在开始的时候总是分配一些非常简单的任务&#xff0c;例如GPIO driver、LED driver。往往CPU datasheet的关于GPIO…

初识函数集锦

python之路——初识函数 阅读目录 为什么要用函数  函数的定义与调用  函数的返回值  函数的参数  本章小结为什么要用函数 现在有一个需求&#xff0c;让你计算hello world的长度&#xff0c;你怎么计算&#xff1f; s1hello world length0 for i in s1:length1 print…

送你一个Git命令地图

上周&#xff0c;公众号举办了一个活动&#xff0c;抽取Git鼠标垫&#xff0c;现在已经结束了&#xff0c;大家不用再过去找&#xff0c;周末我收到了鼠标垫&#xff0c;然后看到有几个读者朋友圈也发了&#xff0c;我感觉也算是做了一个好事&#xff0c;拿到鼠标垫&#xff0c…

文件的权限与隐藏属性

一、文件的属性 1. 权限详解 r 表示读权限————————————读取文件内容 w 表示写权限————————————编辑、新增、修改内容(非删除) x 代表执行权限———————————读取文件内容 — 表示没有该权限——————————读取文件内容 2. 权限对目录的重…