亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Java讀取Excel文件內容的簡單實例

2019-11-26 15:53:22
字體:
來源:轉載
供稿:網友

借助于apathe的poi.jar,由于上傳文件不支持.jar所以請下載后將文件改為.jar,在應用程序中添加poi.jar包,并將需要讀取的excel文件放入根目錄即可

本例使用java來讀取excel的內容并展出出結果,代碼如下:

復制代碼 代碼如下:

import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;

public class ExcelOperate {

    public static void main(String[] args) throws Exception {
       File file = new File("ExcelDemo.xls");
       String[][] result = getData(file, 1);
       int rowLength = result.length;
       for(int i=0;i<rowLength;i++) {
           for(int j=0;j<result[i].length;j++) {
              System.out.print(result[i][j]+"/t/t");
           }
           System.out.println();
       }

    }
    /**
     * 讀取Excel的內容,第一維數組存儲的是一行中格列的值,二維數組存儲的是多少個行
     * @param file 讀取數據的源Excel
     * @param ignoreRows 讀取數據忽略的行數,比喻行頭不需要讀入 忽略的行數為1
     * @return 讀出的Excel中數據的內容
     * @throws FileNotFoundException
     * @throws IOException
     */
    public static String[][] getData(File file, int ignoreRows)
           throws FileNotFoundException, IOException {
       List<String[]> result = new ArrayList<String[]>();
       int rowSize = 0;
       BufferedInputStream in = new BufferedInputStream(new FileInputStream(
              file));
       // 打開HSSFWorkbook
       POIFSFileSystem fs = new POIFSFileSystem(in);
       HSSFWorkbook wb = new HSSFWorkbook(fs);
       HSSFCell cell = null;
       for (int sheetIndex = 0; sheetIndex < wb.getNumberOfSheets(); sheetIndex++) {
           HSSFSheet st = wb.getSheetAt(sheetIndex);
           // 第一行為標題,不取
           for (int rowIndex = ignoreRows; rowIndex <= st.getLastRowNum(); rowIndex++) {
              HSSFRow row = st.getRow(rowIndex);
              if (row == null) {
                  continue;
              }
              int tempRowSize = row.getLastCellNum() + 1;
              if (tempRowSize > rowSize) {
                  rowSize = tempRowSize;
              }
              String[] values = new String[rowSize];
              Arrays.fill(values, "");
              boolean hasValue = false;
              for (short columnIndex = 0; columnIndex <= row.getLastCellNum(); columnIndex++) {
                  String value = "";
                  cell = row.getCell(columnIndex);
                  if (cell != null) {
                     // 注意:一定要設成這個,否則可能會出現亂碼
                     cell.setEncoding(HSSFCell.ENCODING_UTF_16);
                     switch (cell.getCellType()) {
                     case HSSFCell.CELL_TYPE_STRING:
                         value = cell.getStringCellValue();
                         break;
                     case HSSFCell.CELL_TYPE_NUMERIC:
                         if (HSSFDateUtil.isCellDateFormatted(cell)) {
                            Date date = cell.getDateCellValue();
                            if (date != null) {
                                value = new SimpleDateFormat("yyyy-MM-dd")
                                       .format(date);
                            } else {
                                value = "";
                            }
                         } else {
                            value = new DecimalFormat("0").format(cell
                                   .getNumericCellValue());
                         }
                         break;
                     case HSSFCell.CELL_TYPE_FORMULA:
                         // 導入時如果為公式生成的數據則無值
                         if (!cell.getStringCellValue().equals("")) {
                            value = cell.getStringCellValue();
                         } else {
                            value = cell.getNumericCellValue() + "";
                         }
                         break;
                     case HSSFCell.CELL_TYPE_BLANK:
                         break;
                     case HSSFCell.CELL_TYPE_ERROR:
                         value = "";
                         break;
                     case HSSFCell.CELL_TYPE_BOOLEAN:
                         value = (cell.getBooleanCellValue() == true ? "Y"
                                : "N");
                         break;
                     default:
                         value = "";
                     }
                  }
                  if (columnIndex == 0 && value.trim().equals("")) {
                     break;
                  }
                  values[columnIndex] = rightTrim(value);
                  hasValue = true;
              }

              if (hasValue) {
                  result.add(values);
              }
           }
       }
       in.close();
       String[][] returnArray = new String[result.size()][rowSize];
       for (int i = 0; i < returnArray.length; i++) {
           returnArray[i] = (String[]) result.get(i);
       }
       return returnArray;
    }

    /**
     * 去掉字符串右邊的空格
     * @param str 要處理的字符串
     * @return 處理后的字符串
     */
     public static String rightTrim(String str) {
       if (str == null) {
           return "";
       }
       int length = str.length();
       for (int i = length - 1; i >= 0; i--) {
           if (str.charAt(i) != 0x20) {
              break;
           }
           length--;
       }
       return str.substring(0, length);
    }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产视频一区二区| 国产成人啪精品视频免费网| 中文字幕日本精品| 亚洲精品日韩av| 久久亚洲国产成人| 亚洲男人av电影| 精品久久久久久久久久ntr影视| 国产精品久久一区| 日韩av在线看| 成人午夜一级二级三级| 在线观看不卡av| 久久久久久久一| 国产精品一区二区三区久久| 欧美午夜精品久久久久久人妖| 亚洲欧美一区二区三区情侣bbw| 日韩精品视频免费在线观看| 成人日韩av在线| 日韩美女在线观看一区| 国产精品久久久久久久久久久久| 97精品一区二区视频在线观看| 欧美乱大交xxxxx另类电影| 国产精品美女久久久久久免费| 亚洲成人国产精品| 亚洲色图在线观看| 91高潮精品免费porn| 亚洲国产成人爱av在线播放| 久久久精品亚洲| 亚洲图片制服诱惑| 日韩av在线播放资源| 97国产精品免费视频| 青青久久aⅴ北条麻妃| 久热在线中文字幕色999舞| 北条麻妃在线一区二区| 亚洲综合色激情五月| 精品国产91久久久久久老师| 亚洲色图35p| 欧美成人h版在线观看| 麻豆国产精品va在线观看不卡| 日韩大片免费观看视频播放| 97精品在线视频| 亚洲精品小视频| 日韩美女视频中文字幕| 国产精品6699| 日韩欧美在线网址| wwwwwwww亚洲| 亚洲精品国产品国语在线| 亚洲www永久成人夜色| 亚洲天堂久久av| 国产精品av在线| 两个人的视频www国产精品| 国产亚洲视频中文字幕视频| 91在线视频成人| 68精品国产免费久久久久久婷婷| 欧美日韩亚洲一区二| 精品国偷自产在线| 欧美极品少妇xxxxⅹ喷水| 在线视频欧美日韩精品| 成人精品久久一区二区三区| 日韩免费av一区二区| 国产精品久久久久aaaa九色| 4438全国亚洲精品在线观看视频| 欧美中文字幕视频| 日韩a**站在线观看| 国产精品一区二区3区| 欧美成人免费在线视频| 欧美性猛交xxxx黑人| 久久电影一区二区| 最近2019年日本中文免费字幕| 2021国产精品视频| 国产精品国语对白| 日韩欧美国产高清91| 成人激情电影一区二区| 亚洲欧美日韩天堂一区二区| 自拍偷拍免费精品| 国产欧美最新羞羞视频在线观看| 亚洲美女在线看| 久久久精品视频成人| 亚洲精品美女在线观看播放| 欧美激情精品久久久久久大尺度| 欧美日韩成人在线播放| 51ⅴ精品国产91久久久久久| 国产精品99免视看9| 国产精品永久免费视频| 亚洲天堂免费视频| 欧美最猛性xxxxx免费| 色999日韩欧美国产| 亚洲男人天堂九九视频| 黑人巨大精品欧美一区二区三区| 成人国内精品久久久久一区| 色综合影院在线| 97国产在线视频| 久久亚洲综合国产精品99麻豆精品福利| 午夜精品一区二区三区在线视| 亚洲激情视频在线| 午夜剧场成人观在线视频免费观看| 精品综合久久久久久97| 国产精品一区二区在线| 亚洲欧美在线一区| 欧美日韩一区二区免费视频| 亚洲色图五月天| 成人中文字幕+乱码+中文字幕| 亚洲国产一区二区三区在线观看| 国产精品丝袜久久久久久高清| 亚洲欧美在线播放| 久久久www成人免费精品张筱雨| 日本精品视频网站| 欧美日韩视频在线| 成人在线播放av| 精品中文字幕在线2019| 亚洲国产欧美在线成人app| 91在线观看免费高清| 神马国产精品影院av| 国产精品极品尤物在线观看| 日韩久久免费电影| 在线播放日韩精品| 日韩亚洲国产中文字幕| 欧美激情一区二区三区高清视频| 91亚洲国产成人久久精品网站| 久久最新资源网| 91色琪琪电影亚洲精品久久| 亚洲国产精品推荐| 国产成人精品视频在线| 57pao精品| 国产精品精品国产| 亚洲激情成人网| 亚洲在线视频观看| 亚洲欧美日韩在线高清直播| 丝袜一区二区三区| 久久精品亚洲精品| 国产欧美亚洲精品| 美女视频久久黄| 久久精品国产91精品亚洲| 午夜精品免费视频| 国产精品国产三级国产aⅴ浪潮| 成人国产精品一区二区| 97久久精品视频| 国产精品揄拍500视频| 狠狠久久五月精品中文字幕| 91成人福利在线| 日韩一区视频在线| 国产成人精品优优av| 91久久在线视频| 中文字幕欧美在线| 欧美在线亚洲一区| 中文字幕在线日韩| 久久久精品视频成人| 永久免费精品影视网站| 亚洲男人天堂2024| 欧美激情成人在线视频| 国产精品一区二区三区免费视频| 国产精品高潮呻吟视频| 欧美怡红院视频一区二区三区| 日韩综合中文字幕| 亚洲精品第一国产综合精品| 亚洲欧美日韩国产成人| 久久婷婷国产麻豆91天堂| 亚洲视频视频在线| 精品小视频在线| 欧美成人sm免费视频| 91久久精品美女高潮| 性欧美xxxx交| 人体精品一二三区| 亚洲乱码国产乱码精品精天堂| 一区二区三区视频免费在线观看|