日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

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

發布時間:2024/7/5 Android 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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案例效果圖:

Excel.gif

導入——將外部Excel表格導入到Android中(Android中的數據庫中)。

先看一下Excel表格數據格式。

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表

(二)隱藏表——表是隱藏的,一般都是表回到大系統的時候會有這個。不能忽略,如果忽略,那么表回歸大系統的時候就會報錯。

如何查看隱藏表:

hide.png

點擊鼠標左鍵取消隱藏后,選擇需要顯示的sheet表以及查看有多少張被隱藏的表。

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文件夾下)。

導出.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上。

ExcelQuery.gif

使用此案例,當App安裝到手機上,就會在外部存儲中創建YunYangData文件夾,然后可以把固定的文件格式的Excel文件放入其中。使用App進行處理。(也可以先創建YunYangData文件夾,然后把固定的文件格式的Excel文件放入其中,打開App進行操作)。

此Demo代碼下載

總結

以上是生活随笔為你收集整理的android jxl.jar 使用,使用jxl.jar在Android中操作Excel表格——重中之重——对隐藏表的处理...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。