江蘇公務員職位表導入MySQL

USE `database`;

/*Table structure for table `post` */

DROP TABLE IF EXISTS `post`;

CREATE TABLE `post` (
  `no` int(11) NOT NULL AUTO_INCREMENT COMMENT '序列號',
  `attach` varchar(16) DEFAULT NULL COMMENT '隸屬關係',
  `areaNo` varchar(8) DEFAULT NULL COMMENT '地區編碼',
  `area` varchar(16) DEFAULT NULL COMMENT '地區',
  `unitNo` varchar(8) DEFAULT NULL COMMENT '部門編碼',
  `unit` varchar(64) DEFAULT NULL COMMENT '部門',
  `positionNo` varchar(8) DEFAULT NULL COMMENT '職位代碼',
  `position` varchar(64) DEFAULT NULL COMMENT '職位',
  `positionDesc` varchar(1024) DEFAULT NULL COMMENT '職位簡介',
  `positionType` varchar(2) DEFAULT NULL COMMENT '職位類別',
  `ratio` int(11) DEFAULT NULL COMMENT '開考比例',
  `number` int(11) DEFAULT NULL COMMENT '人數',
  `education` varchar(16) DEFAULT NULL COMMENT '學歷',
  `major` varchar(256) DEFAULT NULL COMMENT '專業',
  `others` varchar(1024) DEFAULT NULL COMMENT '其餘',
  `city` varchar(16) DEFAULT NULL COMMENT '城市/垂直部門',
  PRIMARY KEY (`no`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
package com.jsgwy.xls;

import java.io.BufferedWriter;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;

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 ParseXls
{
    private static FileOutputStream out;
    private static OutputStreamWriter outWriter;
    private static BufferedWriter bufWrite;
    
    public static void main(String[] args) {
        try {
            out = new FileOutputStream("d:/post.sql");
            outWriter = new OutputStreamWriter(out, "UTF-8");
            bufWrite = new BufferedWriter(outWriter);
            
            POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream("d:/test.xls"));
            HSSFWorkbook wb = new HSSFWorkbook(fs);
            for (int i = 0; i < 17; i++) {
                HSSFSheet sheet = wb.getSheetAt(i);
                dealSheet(sheet);
            }
            bufWrite.close();  
            outWriter.close();  
            out.close(); 
            wb.close();
            fs.close();
            System.out.println("done!");
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    
    private static void dealSheet(HSSFSheet sheet) {
        String sheetName  = sheet.getSheetName();
        int    rowCounter = sheet.getLastRowNum();
        for (int i = 3; i < rowCounter; i++) {
            HSSFRow row = sheet.getRow(i);
            int cellCounter = row.getLastCellNum();
            StringBuilder sb = new StringBuilder();
            String tablePrefix  = "INSERT INTO `post`("
                    + "`attach`,`areaNo`,`area`,`unitNo`,`unit`,"
                    + "`positionNo`,`position`,`positionDesc`,`positionType`,"
                    + "`ratio`,`number`,`education`,`major`,`others`,`city`) VALUES ('";
            String attach       = row.getCell(0).getStringCellValue().trim();
            String areaNo       = row.getCell(1).getStringCellValue().trim();
            String area         = row.getCell(2).getStringCellValue().trim();
            String unitNo       = row.getCell(3).getStringCellValue().trim();
            String unit         = row.getCell(4).getStringCellValue().trim();
            String positionNo   = row.getCell(5).getStringCellValue().trim();
            String position     = row.getCell(6).getStringCellValue().trim();
            String positionDesc = row.getCell(7).getStringCellValue().trim();
            String positionType = row.getCell(8).getStringCellValue().trim();
            int    ratio        = (int)(row.getCell(9).getNumericCellValue());
            int    number       = (int)(row.getCell(10).getNumericCellValue());
            String education    = row.getCell(11).getStringCellValue().trim();
            String major        = row.getCell(12).getStringCellValue().trim();
            String others       = "";
            if (cellCounter > 13) {
                others = row.getCell(13).getStringCellValue().trim();
            }
            others = others.replaceAll(";", "<br/>");
            others = others.replaceAll(",", "<br/>");
            String city = sheetName;
            sb.append(tablePrefix).append(attach)
              .append("','").append(areaNo)
              .append("','").append(area)
              .append("','").append(unitNo)
              .append("','").append(unit)
              .append("','").append(positionNo)
              .append("','").append(position)
              .append("','").append(positionDesc)
              .append("','").append(positionType)
              .append("',").append(ratio)
              .append(",").append(number)
              .append(",'").append(education)
              .append("','").append(major)
              .append("','").append(others)
              .append("','").append(city)
              .append("');");
            try {
                bufWrite.write(sb.toString() + "\r\n");  
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}
相關文章
相關標籤/搜索