java讀寫excel

java應用jxl API讀寫excel:java

package tf.excel;

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

import jxl.Cell;
import jxl.CellType;
import jxl.DateCell;
import jxl.LabelCell;
import jxl.NumberCell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.CellFormat;
import jxl.format.Colour;
import jxl.format.VerticalAlignment;
import jxl.write.DateFormats;
import jxl.write.DateTime;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

import common.Logger;

public class JxlTest {

	private static Logger log = Logger.getLogger(JxlTest.class);

	private static SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");

	private File file;

	public JxlTest(String fileName) {
		this.file = new File(fileName);
	}

	public JxlTest(File file) {
		this.file = file;
	}

	public static void main(String[] args) {
		JxlTest jxl = new JxlTest("users.xls");
		jxl.writeExcel();

		List<User> list = jxl.readExcel();
		for (User u : list) {
			log.info(u.yhm + "--" + u.xm + "--" + u.age + "--"
					+ df.format(u.sr));
		}
	}

	public void writeExcel() {
		WritableWorkbook ww;
		try {
			ww = Workbook.createWorkbook(file);
			WritableSheet ws = ww.createSheet("用戶信息", 0);

			Operate.addLabelToSheet(ws, 0, 0, 3, 0, "用戶信息", Style
					.getHeaderStyle());
			Operate.addLabelToSheet(ws, 0, 1, "用戶名", Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 1, 1, "姓名", Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 2, 1, "年齡", Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 3, 1, "生日", Style.getTitleStyle());

			Operate.addLabelToSheet(ws, 0, 2, "tt", Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 1, 2, "糖糖", Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 2, 2, 25, Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 3, 2, df.parse("1984-08-12"), Style
					.getDateStyle());
			Operate.addLabelToSheet(ws, 0, 3, "ff", Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 1, 3, "飛飛", Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 2, 3, 24, Style.getTitleStyle());
			Operate.addLabelToSheet(ws, 3, 3, df.parse("1985-11-25"), Style
					.getDateStyle());

			for (int i = 0; i < 4; i++) {
				ws.setColumnView(i, 16);
			}
			ws.setRowView(0, 20);
			ww.write();
			ww.close();
			log.info("寫入excel成功!");
		} catch (Exception e) {
			log.info("寫入excel失敗!");
			e.printStackTrace();
		}

	}

	public List<User> readExcel() {
		List<User> list = new ArrayList<User>();
		Workbook wb;
		try {
			wb = Workbook.getWorkbook(file);

			Sheet sheet = wb.getSheet(0);
			int row = sheet.getRows();
			int col = sheet.getColumns();
			for (int i = 2; i < row; i++) {
				User user = new User();
				for (int j = 0; j < col; j++) {
					Cell cell = sheet.getCell(j, i);

					if (cell.getType() == CellType.LABEL) {
						LabelCell lc = (LabelCell) cell;
						switch (j) {
						case 0:
							user.setYhm(lc.getContents());
						case 1:
							user.setXm(lc.getContents());
						}
					}

					if (cell.getType() == CellType.NUMBER) {
						NumberCell nc = (NumberCell) cell;
						user.setAge((int) nc.getValue());
					}

					if (cell.getType() == CellType.DATE) {
						DateCell dc = (DateCell) cell;
						user.setSr(dc.getDate());
					}
				}
				list.add(user);
			}
			log.info("讀取excel成功!");
		} catch (Exception e) {
			log.info("讀取excel失敗!");
			e.printStackTrace();
		}
		return list;

	}

	static class Style {
		/**
		 * 頁頭樣式
		 */
		public static WritableCellFormat getHeaderStyle() throws Exception {
			WritableFont font = new WritableFont(WritableFont.TIMES, 14); // 設置14號字體
			font.setColour(Colour.BLUE); // 設置字體顏色
			font.setBoldStyle(WritableFont.BOLD); // 設置粗體字
			WritableCellFormat format = new WritableCellFormat(font); // 設置單元格樣式
			format.setBackground(Colour.LIGHT_GREEN); // 設置背景顏色
			format.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);//設置邊界樣式
			format.setAlignment(Alignment.CENTRE); // 設置水平位置
			format.setVerticalAlignment(VerticalAlignment.CENTRE); // 設置豎直位置
			return format;
		}

		/**
		 * 標題樣式
		 */
		public static WritableCellFormat getTitleStyle() throws Exception {
			WritableFont font = new WritableFont(WritableFont.TIMES, 14);
			font.setColour(Colour.GREEN);
			WritableCellFormat format = new WritableCellFormat(font);
			format.setBackground(Colour.VERY_LIGHT_YELLOW);
			format.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
			format.setAlignment(Alignment.CENTRE);
			format.setVerticalAlignment(VerticalAlignment.CENTRE);
			return format;
		}

		/**
		 * 內容樣式
		 */
		public static WritableCellFormat getContentStyle() throws Exception {
			WritableFont font = new WritableFont(WritableFont.TIMES, 14);
			font.setColour(Colour.BLUE);
			WritableCellFormat format = new WritableCellFormat(font);
			format.setBackground(Colour.VERY_LIGHT_YELLOW);
			format.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
			format.setAlignment(Alignment.CENTRE);
			format.setVerticalAlignment(VerticalAlignment.CENTRE);
			return format;
		}

		/**
		 * 普通樣式
		 */
		public static WritableCellFormat getNormalStyle() throws Exception {
			WritableFont font = new WritableFont(WritableFont.TIMES, 14);
			font.setColour(Colour.BLUE);
			WritableCellFormat format = new WritableCellFormat(
					DateFormats.FORMAT12);
			format.setBackground(Colour.VERY_LIGHT_YELLOW);
			format.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
			format.setAlignment(Alignment.CENTRE);
			format.setVerticalAlignment(VerticalAlignment.CENTRE);
			return format;
		}

		/**
		 * 日期樣式
		 */
		public static WritableCellFormat getDateStyle() throws Exception {
			WritableFont font = new WritableFont(WritableFont.TIMES, 14);
			font.setColour(Colour.BLUE);
			WritableCellFormat format = new WritableCellFormat(
					DateFormats.FORMAT1);
			format.setBackground(Colour.VERY_LIGHT_YELLOW);
			format.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
			format.setAlignment(Alignment.CENTRE);
			format.setVerticalAlignment(VerticalAlignment.CENTRE);
			return format;
		}
	}

	static class Operate {
		/**
		 * 寫入文本
		 */
		public static void addLabelToSheet(WritableSheet ws, int col, int row,
				String cont, CellFormat format) throws Exception {
			Label label = new Label(col, row, cont, format);
			ws.addCell(label);
		}

		/**
		 * 寫入文本(合併後的單元格)
		 */
		public static void addLabelToSheet(WritableSheet ws, int firstCol,
				int firstRow, int lastCol, int lastRow, String cont,
				CellFormat format) throws Exception {
			ws.mergeCells(firstCol, firstRow, lastCol, lastRow);
			addLabelToSheet(ws, firstCol, firstRow, cont, format);
		}

		/**
		 * 寫入數字
		 */
		public static void addLabelToSheet(WritableSheet ws, int col, int row,
				double num, CellFormat format) throws Exception {
			jxl.write.Number number = new jxl.write.Number(col, row, num,
					format);
			ws.addCell(number);
		}

		/**
		 * 寫入日期
		 */
		public static void addLabelToSheet(WritableSheet ws, int col, int row,
				Date date, CellFormat format) throws Exception {

			DateTime dt = new DateTime(col, row, date, format, DateTime.GMT);
			ws.addCell(dt);
		}
	}

	static class User {
		private String yhm;
		private String xm;
		private int age;
		private Date sr;

		public String getYhm() {
			return yhm;
		}

		public void setYhm(String yhm) {
			this.yhm = yhm;
		}

		public String getXm() {
			return xm;
		}

		public void setXm(String xm) {
			this.xm = xm;
		}

		public int getAge() {
			return age;
		}

		public void setAge(int age) {
			this.age = age;
		}

		public Date getSr() {
			return sr;
		}

		public void setSr(Date sr) {
			this.sr = sr;
		}
	}
}
相關文章
相關標籤/搜索