jxl操作excel示例

     该例主要实现了将excel的值导入到mysql数据库当中来,为了方便将数据库的值都改了varchar类型,实现的比较粗糙,仅供参考。

     所用jar包:
     mysql-connector-java-5.1.7-bin.jar
     jxl.jar
     commons-logging-1.0.4.jar
     commons-lang-2.3.jar

import java.io.File;
import java.io.IOException;
import java.sql.Date;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;

import jxl.Cell;
import jxl.CellType;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableCell;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;

public class ReadWriteExcelUtil {

	/**
	 * @param args 
	 */
	public static void main(String[] args) {
		String fileName = "d:" + File.separator + "其他.xls";
		List list = ReadWriteExcelUtil.readExcel(fileName);
		DBUtil.batch(list);
	}

	/**
	 * 從excel文件中讀取所有的內容
	 * 
	 * @param file
	 *            excel文件
	 * @return excel文件的內容
	 */
	public static List<Zhaopin> readExcel(String fileName) {
		List list = new ArrayList();
		Workbook wb = null;
		try {
			// 构造Workbook(工作薄)对象
			wb = Workbook.getWorkbook(new File(fileName));
		} catch (BiffException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}

		if (wb == null)
			return null;

		// 获得了Workbook对象之后,就可以通过它得到Sheet(工作表)对象了
		Sheet[] sheet = wb.getSheets();

		if (sheet != null && sheet.length > 0) {
			// 对每个工作表进行循环
			for (int i = 0; i < sheet.length; i++) {
				// 得到当前工作表的行数
				int rowNum = sheet[i].getRows();
				for (int j = 1; j < rowNum; j++) {
					// 得到当前行的所有单元格
					Cell[] cells = sheet[i].getRow(j);

					ArrayList temp = new ArrayList();
					if (cells != null && cells.length > 0) {
						// 对每个单元格进行循环
						for (int k = 0; k < cells.length; k++) {
							// 读取当前单元格的类型
							CellType type = cells[i].getType();

							// 读取当前单元格的值
							String cellValue = cells[k].getContents();
							temp.add(k, formateDate(type, cellValue));
						}
					}
					list.add(temp);
					// sb.append("\r\n");
				}
				// sb.append("\r\n");
			}
		}
		// 最后关闭资源,释放内存
		wb.close();
		return list;
	}

	/**
	 * 该方法将日期格式转换为想要的格式
	 * 
	 * @param type
	 *            单元格的类型
	 * @param value
	 *            单元格的值
	 * @return
	 */
	public static String formateDate(CellType type, String value) {
		String str = value;
		if (CellType.DATE == type) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
			try {
				Date dd = (Date) sdf.parse(value.toString());
				return sdf.format(dd);
			} catch (ParseException e) {
			}
		}
		return str;
	}

	/**
	 * 把內容寫入excel文件中
	 * 
	 * @param fileName
	 *            要寫入的文件的名稱
	 */
	public static void writeExcel(String fileName) {
		WritableWorkbook wwb = null;
		try {
			// 首先要使用Workbook类的工厂方法创建一个可写入的工作薄(Workbook)对象
			wwb = Workbook.createWorkbook(new File(fileName));
		} catch (IOException e) {
			e.printStackTrace();
		}
		if (wwb != null) {
			// 创建一个可写入的工作表
			// Workbook的createSheet方法有两个参数,第一个是工作表的名称,第二个是工作表在工作薄中的位置
			WritableSheet ws = wwb.createSheet("sheet1", 0);

			// 下面开始添加单元格
			for (int i = 0; i < 10; i++) {
				for (int j = 0; j < 5; j++) {
					// 这里需要注意的是,在Excel中,第一个参数表示列,第二个表示行
					Label labelC = new Label(j, i, "这是第" + (i + 1) + "行,第"
							+ (j + 1) + "列");
					// Label labelC=new Label();
					try {
						// 将生成的单元格添加到工作表中
						ws.addCell((WritableCell) labelC);
					} catch (RowsExceededException e) {
						e.printStackTrace();
					} catch (WriteException e) {
						e.printStackTrace();
					}
				}
			}

			try {
				// 从内存中写入文件中
				wwb.write();
				// 关闭资源,释放内存
				wwb.close();
			} catch (IOException e) {
				e.printStackTrace();
			} catch (WriteException e) {
				e.printStackTrace();
			}
		}
	}
}
bean

public class Zhaopin {
	private int id;
	private String qudao;
	private String laiyuan;
	private String ispay;
	private	String posttime;
	private String fuzeren;
	private String gangwei;
	private String name;
	private String sex;
	private String age;
	private String xueli;
	private String phone;
	private String email;
	private String salary;
	private String addr;
	//...setter()/getter()
}
DBUtil

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;

public class DBUtil {
	private static String user = "root";
	private static String passwd = "root1230";
	private static String driverClass = "com.mysql.jdbc.Driver";

	public static Connection getConnection() {
		Connection conn = null;
		try {
			Class.forName(driverClass);
			conn = DriverManager.getConnection(
					"jdbc:mysql://127.0.0.1:3306/test", user, passwd);
		} catch (ClassNotFoundException e) {
			e.printStackTrace();
		} catch (SQLException e) {
			e.printStackTrace();
		}
		return conn;
	}

	public static void releaseConn(Connection conn, PreparedStatement ps,
			ResultSet rs) {
		try {
			if (conn != null) {
				conn.close();
			}
			if (ps != null) {
				ps.close();
			}
			if (rs != null) {
				rs.close();
			}

		} catch (SQLException e) {
			e.printStackTrace();
		}
	}

	public static void batch(List list) {
		String sql = "insert into tb_zhaopin(qudao,laiyuan,ispay,posttime,fuzeren,gangwei,name,sex,age,xueli,phone,email,salary,addr)values(?,?,?,?,?,?,?,?,?,?,?,?,?,?)";
		Connection conn = null;
		PreparedStatement ps = null;
		ResultSet rs = null;
		try {
			conn = DBUtil.getConnection();
			conn.setAutoCommit(false);
			ps = conn.prepareStatement(sql);
			ArrayList list2=null;
			int count=0;
			
			for (int i = 0; i < list.size(); i++) {
				list2 = (ArrayList) list.get(i);
				if (list2 != null) {
					for(int j=0;j<list2.size();j++){
						ps.setString(j+1, (String) list2.get(j));
					}
					ps.addBatch();
					count++;
					if((count+500)%500==0){
						ps.executeBatch();
						ps.clearBatch();
						count=1;
						conn.commit();
					}
				}
			}
	
			//判断是否有剩余的没有被处理的. 
			if(count%500!=0){
				ps.executeBatch();
				ps.clearBatch();
				conn.commit();
			}
		} catch (Exception e) {
			e.printStackTrace();
		} finally {
			DBUtil.releaseConn(conn, ps, rs);
		}
	}
}
所用的excel表格:



sql语句:

CREATE TABLE `tb_zhaopin` (
  `id` int(12) NOT NULL AUTO_INCREMENT,
  `qudao` varchar(20) DEFAULT NULL,
  `laiyuan` varchar(20) DEFAULT NULL,
  `ispay` varchar(12) DEFAULT NULL,
  `posttime` varchar(12) DEFAULT NULL,
  `fuzeren` varchar(20) DEFAULT NULL,
  `gangwei` varchar(20) DEFAULT NULL,
  `name` varchar(20) DEFAULT NULL,
  `sex` varchar(20) DEFAULT NULL,
  `age` varchar(12) DEFAULT NULL,
  `xueli` varchar(20) DEFAULT NULL,
  `phone` varchar(12) DEFAULT NULL,
  `email` varchar(20) DEFAULT NULL,
  `salary` varchar(12) DEFAULT NULL,
  `addr` varchar(20) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8;





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值