国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

Java 讀取excel文件

這篇具有很好參考價(jià)值的文章主要介紹了Java 讀取excel文件。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

導(dǎo)入:

先導(dǎo)入依賴:

<!-- 文件上傳 -->
<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpmime</artifactId>
	<version>4.5.7</version>
</dependency>
<!-- JSON -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.41</version>
</dependency>
<!-- POI -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.16</version>
</dependency>

1、獲取想要上傳excel文件的路徑

2、獲得路徑后,通過(guò)路徑定位生成數(shù)據(jù)流,使用FileInputStream方法讀取路徑對(duì)應(yīng)文件的原始字節(jié)流。

//根據(jù)路徑生成 FileInputStream字節(jié)流
FileInputStream inputStream = new FileInputStream(new File(fileName));

3、使用ExcelUtils工具類讀取 字節(jié)流 + 路徑。

//通過(guò)ExcelUtils工具將Excel數(shù)據(jù)存入到list中,工具代碼下面細(xì)講,這一步讀取Excel已經(jīng)完成了,如果不想進(jìn)行插入數(shù)據(jù)庫(kù)操作,可以直接拿著list用啦。
List<List<Object>> list = ExcelUtils.getListByExcel(inputStream,fileName);

4、ExcelUtils工具類對(duì)數(shù)據(jù)進(jìn)行處理,因?yàn)楸砀裼行泻土校蕴幚硗陻?shù)據(jù)使用二維集合List<List>對(duì)數(shù)據(jù)進(jìn)行存儲(chǔ)。

ExcelUtils類講解:

public class ExcelUtils {
    private final static String excel2003L =".xls";    //2003- 版本的excel
    private final static String excel2007U =".xlsx";  //2007版本
 
    /**
     * @Description:獲取IO流中的數(shù)據(jù),組裝成List<List<Object>>對(duì)象
     * @param in,fileName
     * @return
     * @throws
     */
    public static List<List<Object>> getListByExcel(InputStream in, String fileName) throws Exception{
        List<List<Object>> list = null;
        //創(chuàng)建Excel工作薄
        Workbook work = getWorkbook(in,fileName);
        if(null == work){
            throw new Exception("創(chuàng)建Excel工作薄為空!");
        }
        Sheet sheet = null;  //頁(yè)數(shù)
        Row row = null;  //行數(shù)
        Cell cell = null;  //列數(shù)
 
        list = new ArrayList<List<Object>>();
        //遍歷Excel中所有的sheet
        for (int i = 0; i < work.getNumberOfSheets(); i++) {
            sheet = work.getSheetAt(i);
            if(sheet==null){continue;}
 
            //遍歷當(dāng)前sheet中的所有行
            for (int j = sheet.getFirstRowNum(); j <= sheet.getLastRowNum(); j++) {
                row = sheet.getRow(j);
                if(row==null){continue;}
 
                //遍歷所有的列
                List<Object> li = new ArrayList<Object>();
                for (int y = row.getFirstCellNum(); y < row.getLastCellNum(); y++) {
                    cell = row.getCell(y);
                    li.add(getValue(cell));
                }
                list.add(li);
            }
        }
 
        return list;
 
    }
 
    /**
     * @Description:根據(jù)文件后綴,自適應(yīng)上傳文件的版本
     * @param inStr,fileName
     * @return
     * @throws Exception
     */
    public static  Workbook getWorkbook(InputStream inStr,String fileName) throws Exception{
        Workbook wb = null;
        String fileType = fileName.substring(fileName.lastIndexOf("."));
        if(excel2003L.equals(fileType)){
            wb = new HSSFWorkbook(inStr);  //2003-
        }else if(excel2007U.equals(fileType)){
            wb = new XSSFWorkbook(inStr);  //2007+
        }else{
            throw new Exception("解析的文件格式有誤!");
        }
        return wb;
    }
 
    /**
     * @Description:對(duì)表格中數(shù)值進(jìn)行格式化
     * @param cell
     * @return
     */
    //解決excel類型問(wèn)題,獲得數(shù)值
    public static String getValue(Cell cell) {
        String value = "";
        if(null==cell){
            return value;
        }
        switch (cell.getCellType()) {
            //數(shù)值型
            case NUMERIC:
                if (DateUtil.isCellDateFormatted(cell)) {
                    //如果是date類型則 ,獲取該cell的date值
                    Date date = DateUtil.getJavaDate(cell.getNumericCellValue());
                    SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
                    value = format.format(date);;
                }else {// 純數(shù)字
                    BigDecimal big=new BigDecimal(cell.getNumericCellValue());
                    value = big.toString();
                    //解決1234.0  去掉后面的.0
                    if(null!=value&&!"".equals(value.trim())){
                        String[] item = value.split("[.]");
                        if(1<item.length&&"0".equals(item[1])){
                            value=item[0];
                        }
                    }
                }
                break;
            //字符串類型
            case STRING:
                value = cell.getStringCellValue();
                break;
            // 公式類型
            case FORMULA:
                //讀公式計(jì)算值
                value = String.valueOf(cell.getNumericCellValue());
                if (value.equals("NaN")) {// 如果獲取的數(shù)據(jù)值為非法值,則轉(zhuǎn)換為獲取字符串
                    value = cell.getStringCellValue();
                }
                break;
            // 布爾類型
            case BOOLEAN:
                value = " "+ cell.getBooleanCellValue();
                break;
            default:
                value = cell.getStringCellValue();
        }
        if("null".endsWith(value.trim())){
            value="";
        }
        return value;
    }
}

5、已經(jīng)獲取到了Excel表格中所有的數(shù)據(jù),包含所有的行和列,都在List<List>中,這一步所有的數(shù)據(jù)獲取完了

6、有了數(shù)據(jù),要將數(shù)據(jù)存儲(chǔ)到數(shù)據(jù)庫(kù)。

7、需要?jiǎng)?chuàng)建數(shù)據(jù)庫(kù)字段的實(shí)體類,使用@Excel注解將表格和數(shù)據(jù)庫(kù)字段名一一對(duì)應(yīng)

@Data
@TableName("t_student")//數(shù)據(jù)庫(kù)名字
public class Student{
 
        @TableId(type = IdType.AUTO)
        @Excel(name = "序號(hào)", cellType = Excel.ColumnType.NUMERIC)
        private Long id;
 
        @Excel(name = "學(xué)生ID")
        private Long id;
 
        @Excel(name = "名稱")
        private String name;
 
        @Excel(name = "性別")
        private String sex;
 
        @Excel(name = "年齡")
        private String age;
 
      
        
}

8、通過(guò)雙重 for循環(huán)遍歷List<List>,內(nèi)層List為列,外層List為行,如下圖將第一行數(shù)據(jù)單獨(dú)拿出來(lái),作為判斷字段,如果實(shí)體類等@Excel注解屬性和Excel表格第一行名字相同,對(duì)實(shí)體類進(jìn)行set賦值

//定義Excel第一行的屬性
List<Object> firstRows = null;
//獲取第一行屬性 放入firstRows中。
if(list != null && list.size() > 0){
	firstRows = list.get(0);
}
//遍歷除第一行以外的Excel表格中的值
for (int i = 1; i < list.size(); i++) {
    //rows是某一行,i = 1 為第二行,	i = 2 為第三行
    List<Object> rows = list.get(i);
    //數(shù)據(jù)庫(kù)數(shù)據(jù)的實(shí)體類
    Student student =new student();
    //遍歷這一行所有的值
    for (int j = 0; j < rows.size(); j++){
    //某一行的某一列 j為列的坐標(biāo)    
    String cellVal = (String) rows.get(j);
     //對(duì)實(shí)體類進(jìn)行賦值,使用setFieldValueByFieldName方法,下面詳細(xì)講代碼
    TestExcel.setFieldValueByFieldName(questionBank, firstRows.get(j).toString().trim(), 	 cellVal);
                    }
 
                }
     // 使用spring插入到數(shù)據(jù)庫(kù)
     questionBankService.save(questionBank);
            }

9、從第二行開始,每遍歷完一行,將獲得一個(gè)實(shí)體類對(duì)象,因?yàn)槭墙Y(jié)合數(shù)據(jù)庫(kù)寫的實(shí)體類,通過(guò)springboot可以直接插入數(shù)據(jù)庫(kù)。

public class TestExcel {
 
    /**
     * 用反射方法,獲取列名,比較,為屬性賦值
     * @param object
     * @param fieldName
     * @param val
     */
    public static void setFieldValueByFieldName(Object object, String fieldName, Object val) {
        try {
            //通過(guò)反射獲取所有實(shí)體類所有定義的方法,object為數(shù)據(jù)庫(kù)實(shí)體類
            Field[] fields = object.getClass().getDeclaredFields();
            //遍歷fields
            for (int i = 0; i < fields.length; i++) {
                Field field = fields[i];
                //讀取注釋,如@Excel(name = "科目")
                Excel annotation = field.getAnnotation(Excel.class);
                //因?yàn)閜rivate類型,所有要設(shè)置允許
                field.setAccessible(true);
                //annotation.name() 注解里的屬性,如果annotation沒(méi)寫注解,讀取原始名字如subject
                if(annotation == null){
                    if(fieldName.equals(field.getName())){
                        if(field.getType() == Integer.class){
                            field.set(object, Integer.valueOf(val.toString()));
                        }else if(field.getType() == Long.class){
                            field.set(object, Long.valueOf(val.toString()));
                        }else {
                            field.set(object, val);
                        }
                        return;
                    }  
                }else {//設(shè)置了注解,并且表格里的Excel字段值和注解的name值相同,則為相應(yīng)字段賦值
                    if(fieldName.equals(annotation.name())){
                        //進(jìn)行類型判斷,因?yàn)閷?shí)體類中變量類型不同。
                        if(field.getType() == Integer.class){
                            field.set(object, Integer.valueOf(val.toString()));
                        }else if(field.getType() == Long.class){
                            field.set(object, Long.valueOf(val.toString()));
                        }else {
                            field.set(object, val);
                        }
                        return;
                    }
                }
 
            }
        }catch (Exception e){
            e.printStackTrace();
        }
    }
 
}

六、通用讀取excel工具類?文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-758568.html

package com.ssm;
 
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
 
import org.apache.poi.hssf.usermodel.HSSFCell;
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.ss.usermodel.CellType;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
 
public class ReadExcel {
	
	public List<Map<String,String>> readExcel(String filepath, String filename, int startrow, int startcol, int sheetnum) {
		List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
		String suffix = filename.substring(filename.lastIndexOf(".") + 1);
		if ("xls".equals(suffix)) {
			varList = readExcel2003(filepath, filename, startrow, startcol, sheetnum);
		} else if ("xlsx".equals(suffix)) {
			varList = readExcel2007(filepath, filename, startrow, startcol, sheetnum);
		} else {
			System.out.println("Only excel files with XLS or XLSX suffixes are allowed to be read!");
			return null;
		}
		return varList;
	}
    
 
   
    /**
	 * 讀取2003Excel
	 * 
	 * @param filepath 文件路徑
	 * @param filename 文件名,包括擴(kuò)展名
	 * @param startrow 開始行號(hào),索引從0開始
	 * @param startcol 開始列號(hào),索引從0開始
	 * @param sheetnum 工作簿,索引從0開始
	 * @return
	 */
	public static List<Map<String,String>> readExcel2003(String filepath, String filename, int startrow, int startcol, int sheetnum) {
		List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
		try {
			File target = new File(filepath, filename);
			FileInputStream fis = new FileInputStream(target);
			HSSFWorkbook wb = new HSSFWorkbook(fis);
			fis.close();
			// sheet 從0開始
			HSSFSheet sheet = wb.getSheetAt(sheetnum);
			// 取得最后一行的行號(hào)
			int rowNum = sheet.getLastRowNum() + 1;
 
			HSSFRow rowTitle = sheet.getRow(0);
			// 標(biāo)題行的最后一個(gè)單元格位置
			int cellTitleNum = rowTitle.getLastCellNum();
			String[] title = new String[cellTitleNum];
			for (int i = startcol; i < cellTitleNum; i++) {
				HSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
				if (cell != null) {
					cell.setCellType(CellType.STRING);
					title[i] = cell.getStringCellValue();
				} else {
					title[i] = "";
				}
			}
 
			// 行循環(huán)開始
			for (int i = startrow + 1; i < rowNum; i++) {
				Map<String, String> varpd = new HashMap<String, String>();
				// 行
				HSSFRow row = sheet.getRow(i);
				// 列循環(huán)開始
				for (int j = startcol; j < cellTitleNum; j++) {
 
					HSSFCell cell = row.getCell(Short.parseShort(j + ""));
					String cellValue = "";
					if (cell != null) {
						// 把類型先設(shè)置為字符串類型
						cell.setCellType(CellType.STRING);
						cellValue = cell.getStringCellValue();
					}
					varpd.put(title[j], cellValue);
				}
				varList.add(varpd);
			}
			wb.close();
		} catch (Exception e) {
			System.out.println(e);
		}
		return varList;
	}
	
	/**
	 * 讀取2007Excel
	 * 
	 * @param filepath 文件路徑
	 * @param filename 文件名,包括擴(kuò)展名
	 * @param startrow 開始行號(hào),索引從0開始
	 * @param startcol 開始列號(hào),索引從0開始
	 * @param sheetnum 工作簿,索引從0開始
	 * @return
	 */
	public List<Map<String,String>> readExcel2007(String filepath, String filename, int startrow, int startcol, int sheetnum) {
		List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
		try {
			File target = new File(filepath, filename);
			InputStream ins = new FileInputStream(target);
			XSSFWorkbook wb = new XSSFWorkbook(ins);
			ins.close();
			// 得到Excel工作表對(duì)象
			XSSFSheet sheet = wb.getSheetAt(sheetnum);
			// 取得最后一行的行號(hào)
			int rowNum = sheet.getLastRowNum() + 1;
 
			XSSFRow rowTitle = sheet.getRow(0);
			int cellTitleNum = rowTitle.getLastCellNum();
			String[] title = new String[cellTitleNum];
			for (int i = startcol; i < cellTitleNum; i++) {
				XSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
				if (cell != null) {
					// 把類型先設(shè)置為字符串類型
					cell.setCellType(CellType.STRING);
					title[i] = cell.getStringCellValue();
				} else {
					title[i] = "";
				}
			}
 
			// 行循環(huán)開始
			for (int i = startrow + 1; i < rowNum; i++) {
				Map<String, String> varpd = new HashMap<String, String>();
				// 得到Excel工作表的行
				XSSFRow row = sheet.getRow(i);
				// 列循環(huán)開始
				for (int j = startcol; j < cellTitleNum; j++) {
					// 得到Excel工作表指定行的單元格
					XSSFCell cell = row.getCell(j);
					String cellValue = "";
					if (cell != null) {
						// 把類型先設(shè)置為字符串類型
						cell.setCellType(CellType.STRING);
						cellValue = cell.getStringCellValue();
					}
					varpd.put(title[j], cellValue);
				}
				varList.add(varpd);
			}
			wb.close();
		} catch (Exception e) {
			System.out.println(e);
		}
		return varList;
	}
    
    
    
    
    
    
    
    
    
}

到了這里,關(guān)于Java 讀取excel文件的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • C# 讀取Execl文件3種方法

    C# 讀取Execl文件3種方法

    1.1C#提供的數(shù)據(jù)連接有哪些 ????????對(duì)于不同的.net數(shù)據(jù)提供者,ADO.NET采用不同的Connection對(duì)象連接數(shù)據(jù)庫(kù)。這些Connection對(duì)我們屏蔽了具體的實(shí)現(xiàn)細(xì)節(jié),并提供了一種統(tǒng)一的實(shí)現(xiàn)方法。 Connection類有四種:SqlConnection,OleDbConnection,OdbcConnection和OracleConnection。 Sqlconnetcion類的對(duì)

    2024年02月07日
    瀏覽(22)
  • 【python】Excel文件的讀取操作

    【python】Excel文件的讀取操作

    ?輸出結(jié)果: 需要注意的是,我用的xlrd版本是 1.2.0,不是最新版本的,最新版本可能不支持讀取xlsx,所以才會(huì)出現(xiàn)讀取xlsx文件報(bào)錯(cuò)的情況,自行降版本試下 ?輸出結(jié)果: ?使用pandas模塊讀取Excel文件時(shí),可能會(huì)報(bào):ImportError: Missing optional dependency \\\'openpyxl\\\'. Use pip or conda to ins

    2024年02月13日
    瀏覽(26)
  • Python 創(chuàng)建或讀取 Excel 文件

    Python 創(chuàng)建或讀取 Excel 文件

    Excel是一種常用的電子表格軟件,廣泛應(yīng)用于金融、商業(yè)和教育等領(lǐng)域。它提供了強(qiáng)大的數(shù)據(jù)處理和分析功能,可進(jìn)行各種計(jì)算和公式運(yùn)算,并能創(chuàng)建各種類型的圖表和可視化數(shù)據(jù)。Excel的靈活性使其成為處理和管理數(shù)據(jù)的重要工具。本文將介紹如何使用? Spire.XLS for Python? 通

    2024年02月10日
    瀏覽(17)
  • Java 讀取 Excel 表格—— Easy Excel 基本使用

    Java 讀取 Excel 表格—— Easy Excel 基本使用

    確定表頭:建立對(duì)象,和表頭形成映射關(guān)系。 不確定表頭:每一行數(shù)據(jù)映射為 MapString, Object ,比如用戶自己上傳的表格。 監(jiān)聽器:先創(chuàng)建監(jiān)聽器、在讀取文件時(shí)綁定監(jiān)聽器。單獨(dú)抽離處理邏輯,代碼清晰易于維護(hù);一條一條處理,適用于數(shù)據(jù)量大的場(chǎng)景。 同步讀:無(wú)需創(chuàng)建

    2024年01月21日
    瀏覽(26)
  • java讀取Excel導(dǎo)入去除空行

    java讀取Excel導(dǎo)入去除空行

    問(wèn)題: 在Java讀取Excel導(dǎo)入操作時(shí), sheet.getLastRowNum()會(huì)統(tǒng)計(jì)帶有格式的空白行,導(dǎo)致獲取的最大行數(shù)不準(zhǔn)確,數(shù)據(jù)導(dǎo)入失敗。 解決: 在操作過(guò)程中刪除存在樣式的空白行 可通過(guò)將空白行(內(nèi)容為空,但是存在樣式)進(jìn)行sheet.removeRow刪除后 再調(diào)用getLastRowNum()進(jìn)行行數(shù)統(tǒng)計(jì),getAcc

    2024年02月15日
    瀏覽(26)
  • java讀取excel中的數(shù)據(jù)

    首先導(dǎo)入相關(guān)的依賴: 測(cè)試代碼: 數(shù)據(jù)打印到控制臺(tái)的效果:

    2024年02月06日
    瀏覽(19)
  • Python讀取寫入數(shù)據(jù)到Excel文件

    Python讀取寫入數(shù)據(jù)到Excel文件

    【Linux干貨教程】Ubuntu Linux 換源詳細(xì)教程 大家好,我是洲洲,歡迎關(guān)注,一個(gè)愛聽周杰倫的程序員。關(guān)注公眾號(hào)【程序員洲洲】即可獲得10G學(xué)習(xí)資料、面試筆記、大廠獨(dú)家學(xué)習(xí)體系路線等…還可以加入技術(shù)交流群歡迎大家在CSDN后臺(tái)私信我! Hello,各位看官老爺們好,洲洲已

    2024年02月12日
    瀏覽(97)
  • JAVA 讀取jar包中excel模板

    JAVA 讀取jar包中excel模板

    1、在resources路徑下,新建report文件夾,放入excel模板 2、配置文件中的目錄,分隔符使用 / 3、使用getResourceAsStream()讀取

    2024年02月11日
    瀏覽(18)
  • 如何使用 Java 靈活讀取 Excel 內(nèi)容?

    在日常工作和學(xué)習(xí)中,我們經(jīng)常需要從 Excel 文件中讀取數(shù)據(jù)。對(duì)于少量數(shù)據(jù),手動(dòng)復(fù)制和粘貼可能是可行的,但是對(duì)于大量的數(shù)據(jù),這種方法會(huì)變得非常低效。在這種情況下,使用 Java 程序自動(dòng)讀取 Excel 文件中的數(shù)據(jù)將是更好的選擇。 本教程將介紹如何使用 Java 程序讀取

    2024年02月07日
    瀏覽(23)
  • Python讀取csv、Excel文件生成圖表

    Python讀取csv、Excel文件生成圖表

    簡(jiǎn)介 本文章介紹了通過(guò)讀取?csv 或 Excel 文件內(nèi)容,將其轉(zhuǎn)換為折線圖或柱狀圖的方法,并寫入 html 文件中。 目錄 1. 讀取CSV文件 1.1. 生成折線圖 1.1.1. 簡(jiǎn)單生成圖表 1.1.2. 設(shè)置折線圖格式 1.2. 生成柱狀圖 1.2.1. 簡(jiǎn)單生成圖表 1.2.2. 設(shè)置柱狀圖格式 2. 讀取Excel文件 2.1. 生成折線圖

    2024年02月15日
    瀏覽(24)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包