jdbc mysql excel_使用JDBC+POI把Excel中的数据导出到MySQL

在项目中用户需要导入大量Excel表格数据到数据库,为此需求自己写了一个读取Excel数据的Java类,现将代码贴出来与大家一起分享。

该类提供两个方法,一个方法用于读取Excel表格的表头,另一个方法用于读取Excel表格的内容。

(注:本类需要POI组件的支持,POI是apache组织下的一个开源组件,)

代码如下:

Java代码 b252f0ad4bab9affa378b60151ad5538.gif

package org.hnylj.poi.util;

importjava.io.FileInputStream;

importjava.io.FileNotFoundException;

importjava.io.IOException;

importjava.io.InputStream;

importjava.util.Date;

importjava.util.HashMap;

importjava.util.Map;

importorg.apache.poi.hssf.usermodel.HSSFCell;

importorg.apache.poi.hssf.usermodel.HSSFRow;

importorg.apache.poi.hssf.usermodel.HSSFSheet;

importorg.apache.poi.hssf.usermodel.HSSFWorkbook;

importorg.apache.poi.poifs.filesystem.POIFSFileSystem;

/**

* 操作Excel表格的功能类

* @author:hnylj

* @version 1.0

*/

publicclassExcelReader {

privatePOIFSFileSystem fs;

privateHSSFWorkbook wb;

privateHSSFSheet sheet;

privateHSSFRow row;

/**

* 读取Excel表格表头的内容

* @param InputStream

* @return String 表头内容的数组

*

*/

publicString[] readExcelTitle(InputStream is) {

try{

fs =newPOIFSFileSystem(is);

wb =newHSSFWorkbook(fs);

}catch(IOException e) {

e.printStackTrace();

}

sheet = wb.getSheetAt(0);

row = sheet.getRow(0);

//标题总列数

intcolNum = row.getPhysicalNumberOfCells();

String[] title =newString[colNum];

for(inti=0; i

title[i] = getStringCellValue(row.getCell((short) i));

}

returntitle;

}

/**

* 读取Excel数据内容

* @param InputStream

* @return Map 包含单元格数据内容的Map对象

*/

publicMap readExcelContent(InputStream is) {

Map content =newHashMap();

String str ="";

try{

fs =newPOIFSFileSystem(is);

wb =newHSSFWorkbook(fs);

}catch(IOException e) {

e.printStackTrace();

}

sheet = wb.getSheetAt(0);

//得到总行数

introwNum = sheet.getLastRowNum();

row = sheet.getRow(0);

intcolNum = row.getPhysicalNumberOfCells();

//正文内容应该从第二行开始,第一行为表头的标题

for(inti =1; i <= rowNum; i++) {

row = sheet.getRow(i);

intj =0;

while(j

//每个单元格的数据内容用"-"分割开,以后需要时用String类的replace()方法还原数据

//也可以将每个单元格的数据设置到一个javabean的属性中,此时需要新建一个javabean

str += getStringCellValue(row.getCell((short) j)).trim() +"-";

j ++;

}

content.put(i, str);

str ="";

}

returncontent;

}

/**

* 获取单元格数据内容为字符串类型的数据

* @param cell Excel单元格

* @return String 单元格数据内容

*/

privateString getStringCellValue(HSSFCell cell) {

String strCell ="";

switch(cell.getCellType()) {

caseHSSFCell.CELL_TYPE_STRING:

strCell = cell.getStringCellValue();

break;

caseHSSFCell.CELL_TYPE_NUMERIC:

strCell = String.valueOf(cell.getNumericCellValue());

break;

caseHSSFCell.CELL_TYPE_BOOLEAN:

strCell = String.valueOf(cell.getBooleanCellValue());

break;

caseHSSFCell.CELL_TYPE_BLANK:

strCell ="";

break;

default:

strCell ="";

break;

}

if(strCell.equals("") || strCell ==null) {

return"";

}

if(cell ==null) {

return"";

}

returnstrCell;

}

/**

* 获取单元格数据内容为日期类型的数据

* @param cell Excel单元格

* @return String 单元格数据内容

*/

privateString getDateCellValue(HSSFCell cell) {

String result ="";

try{

intcellType = cell.getCellType();

if(cellType == HSSFCell.CELL_TYPE_NUMERIC) {

Date date = cell.getDateCellValue();

result = (date.getYear() +1900) +"-"+ (date.getMonth() +1)

+"-"+ date.getDate();

}elseif(cellType == HSSFCell.CELL_TYPE_STRING) {

String date = getStringCellValue(cell);

result = date.replaceAll("[年月]","-").replace("日","").trim();

}elseif(cellType == HSSFCell.CELL_TYPE_BLANK) {

result ="";

}

}catch(Exception e) {

System.out.println("日期格式不正确!");

e.printStackTrace();

}

returnresult;

}

publicstaticvoidmain(String[] args) {

try{

//对读取Excel表格标题测试

InputStream is =newFileInputStream("C:\\Excel表格测试.xls");

ExcelReader excelReader =newExcelReader();

String[] title = excelReader.readExcelTitle(is);

System.out.println("获得Excel表格的标题:");

for(String s : title) {

System.out.print(s +" ");

}

//对读取Excel表格内容测试

InputStream is2 =newFileInputStream("C:\\Excel表格测试.xls");

Map map = excelReader.readExcelContent(is2);

System.out.println("获得Excel表格的内容:");

for(inti=1; i<=map.size(); i++) {

System.out.println(map.get(i));

}

}catch(FileNotFoundException e) {

System.out.println("未找到指定路径的文件!");

e.printStackTrace();

}

}

}

save_snippets.png

Java代码  6a1bcbb00ec1a1cd9be5c37be10a10bb.png

package org.hnylj.poi.util;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.InputStream;

import java.util.Date;

import java.util.HashMap;

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.poifs.filesystem.POIFSFileSystem;

/**

* 操作Excel表格的功能类

* @author:hnylj

* @version 1.0

*/

public class ExcelReader {

private POIFSFileSystem fs;

private HSSFWorkbook wb;

private HSSFSheet sheet;

private HSSFRow row;

/**

* 读取Excel表格表头的内容

* @param InputStream

* @return String 表头内容的数组

*

*/

public String[] readExcelTitle(InputStream is) {

try {

fs = new POIFSFileSystem(is);

wb = new HSSFWorkbook(fs);

} catch (IOException e) {

e.printStackTrace();

}

sheet = wb.getSheetAt(0);

row = sheet.getRow(0);

//标题总列数

int colNum = row.getPhysicalNumberOfCells();

String[] title = new String[colNum];

for (int i=0; i

title[i] = getStringCellValue(row.getCell((short) i));

}

return title;

}

/**

* 读取Excel数据内容

* @param InputStream

* @return Map 包含单元格数据内容的Map对象

*/

public Map readExcelContent(InputStream is) {

Map content = new HashMap();

String str = "";

try {

fs = new POIFSFileSystem(is);

wb = new HSSFWorkbook(fs);

} catch (IOException e) {

e.printStackTrace();

}

sheet = wb.getSheetAt(0);

//得到总行数

int rowNum = sheet.getLastRowNum();

row = sheet.getRow(0);

int colNum = row.getPhysicalNumberOfCells();

//正文内容应该从第二行开始,第一行为表头的标题

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

row = sheet.getRow(i);

int j = 0;

while (j

//每个单元格的数据内容用"-"分割开,以后需要时用String类的replace()方法还原数据

//也可以将每个单元格的数据设置到一个javabean的属性中,此时需要新建一个javabean

str += getStringCellValue(row.getCell((short) j)).trim() + "-";

j ++;

}

content.put(i, str);

str = "";

}

return content;

}

/**

* 获取单元格数据内容为字符串类型的数据

* @param cell Excel单元格

* @return String 单元格数据内容

*/

private String getStringCellValue(HSSFCell cell) {

String strCell = "";

switch (cell.getCellType()) {

case HSSFCell.CELL_TYPE_STRING:

strCell = cell.getStringCellValue();

break;

case HSSFCell.CELL_TYPE_NUMERIC:

strCell = String.valueOf(cell.getNumericCellValue());

break;

case HSSFCell.CELL_TYPE_BOOLEAN:

strCell = String.valueOf(cell.getBooleanCellValue());

break;

case HSSFCell.CELL_TYPE_BLANK:

strCell = "";

break;

default:

strCell = "";

break;

}

if (strCell.equals("") || strCell == null) {

return "";

}

if (cell == null) {

return "";

}

return strCell;

}

/**

* 获取单元格数据内容为日期类型的数据

* @param cell Excel单元格

* @return String 单元格数据内容

*/

private String getDateCellValue(HSSFCell cell) {

String result = "";

try {

int cellType = cell.getCellType();

if (cellType == HSSFCell.CELL_TYPE_NUMERIC) {

Date date = cell.getDateCellValue();

result = (date.getYear() + 1900) + "-" + (date.getMonth() + 1)

+ "-" + date.getDate();

} else if (cellType == HSSFCell.CELL_TYPE_STRING) {

String date = getStringCellValue(cell);

result = date.replaceAll("[年月]", "-").replace("日", "").trim();

} else if (cellType == HSSFCell.CELL_TYPE_BLANK) {

result = "";

}

} catch (Exception e) {

System.out.println("日期格式不正确!");

e.printStackTrace();

}

return result;

}

public static void main(String[] args) {

try {

//对读取Excel表格标题测试

InputStream is = new FileInputStream("C:\\Excel表格测试.xls");

ExcelReader excelReader = new ExcelReader();

String[] title = excelReader.readExcelTitle(is);

System.out.println("获得Excel表格的标题:");

for (String s : title) {

System.out.print(s + " ");

}

//对读取Excel表格内容测试

InputStream is2 = new FileInputStream("C:\\Excel表格测试.xls");

Map map = excelReader.readExcelContent(is2);

System.out.println("获得Excel表格的内容:");

for (int i=1; i<=map.size(); i++) {

System.out.println(map.get(i));

}

} catch (FileNotFoundException e) {

System.out.println("未找到指定路径的文件!");

e.printStackTrace();

}

}

}

save_snippets.png

通过该类提供的方法就能读取出Excel表格中的数据,数据读取出来了,其他的,对这些数据进行怎样的操作,要靠你另外写程序去实现,因为该类只提供读取Excel表格数据的功能。

说明:在该类中有一个getStringCellValue(HSSFCell cell)方法和一个getDateCellValue(HSSFCell cell)方法,前一个方法用于读取那些为字符串类型的数据,如果你的Excel表格中填写的是日期类型的数据,则你应该在readExcelContent(InputStream is)方法里调用getDateCellValue(HSSFCell cell)方法,因为若调用getStringCellValue(HSSFCell cell)方法读取日期类型的数据将得到的是一个浮点数,这很可能不符合实际要求。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个用Java编写的将MySQL数据导出Excel表格的示例代码: ```java import java.io.FileOutputStream; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class MySQLToExcel { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/mydatabase"; String user = "root"; String password = "mypassword"; String query = "SELECT * FROM mytable"; try (Connection con = DriverManager.getConnection(url, user, password); Statement stmt = con.createStatement(); ResultSet rs = stmt.executeQuery(query); XSSFWorkbook workbook = new XSSFWorkbook(); FileOutputStream out = new FileOutputStream("output.xlsx")) { // Create a new sheet in the workbook workbook.createSheet("Data"); // Get the header row and add it to the sheet Row headerRow = workbook.getSheet("Data").createRow(0); int columnCount = rs.getMetaData().getColumnCount(); for (int i = 1; i <= columnCount; i++) { Cell cell = headerRow.createCell(i - 1); cell.setCellValue(rs.getMetaData().getColumnName(i)); } // Get the data rows and add them to the sheet int rowNum = 1; while (rs.next()) { Row dataRow = workbook.getSheet("Data").createRow(rowNum++); for (int i = 1; i <= columnCount; i++) { Cell cell = dataRow.createCell(i - 1); cell.setCellValue(rs.getString(i)); } } // Write the workbook to the output file workbook.write(out); System.out.println("Data exported successfully!"); } catch (Exception e) { e.printStackTrace(); } } } ``` 这个代码使用了 Apache POI 库来创建和写入 Excel 文件。它首先连接到 MySQL 数据库,执行查询语句,然后将结果写入 Excel 文件。你需要将 `url`、`user`、`password` 和 `query` 变量替换为你自己的值,以便它可以连接到你的数据库并执行正确的查询。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值