电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

JAVA導出CSV文件實例教程

瀏覽:6日期:2022-08-31 17:59:36

JAVA導出CSV文件實例教程

以前導出總是用POI導出為Excel文件,后來當我了解到CSV以后,我發現速度飛快。

如果導出的數據不要求格式、樣式、公式等等,建議最好導成CSV文件,因為真的很快。

雖然我們可以用Java再帶的文件相關的類去操作以生成一個CSV文件,但事實上有好多第三方類庫也提供了類似的功能。

這里我們使用apache提供的commons-csv組件

Commons CSV

文檔在這里

http://commons.apache.org/

http://commons.apache.org/proper/commons-csv/

http://commons.apache.org/proper/commons-csv/user-guide.html

先看一下具體用法

@Test public void testWrite() throws Exception { FileOutputStream fos = new FileOutputStream('E:/cjsworkspace/cjs-excel-demo/target/abc.csv'); OutputStreamWriter osw = new OutputStreamWriter(fos, 'GBK'); CSVFormat csvFormat = CSVFormat.DEFAULT.withHeader('姓名', '年齡', '家鄉'); CSVPrinter csvPrinter = new CSVPrinter(osw, csvFormat);// csvPrinter = CSVFormat.DEFAULT.withHeader('姓名', '年齡', '家鄉').print(osw); for (int i = 0; i < 10; i++) { csvPrinter.printRecord('張三', 20, '湖北'); } csvPrinter.flush(); csvPrinter.close(); } @Test public void testRead() throws IOException { InputStream is = new FileInputStream('E:/cjsworkspace/cjs-excel-demo/target/abc.csv'); InputStreamReader isr = new InputStreamReader(is, 'GBK'); Reader reader = new BufferedReader(isr); CSVParser parser = CSVFormat.EXCEL.withHeader('name', 'age', 'jia').parse(reader);// CSVParser csvParser = CSVParser.parse(reader, CSVFormat.DEFAULT.withHeader('name', 'age', 'jia')); List<CSVRecord> list = parser.getRecords(); for (CSVRecord record : list) { System.out.println(record.getRecordNumber() + ':' + record.get('name') + ':' + record.get('age') + ':' + record.get('jia')); } parser.close(); } /** * Parsing an Excel CSV File */ @Test public void testParse() throws Exception { Reader reader = new FileReader('C:/Users/Administrator/Desktop/abc.csv'); CSVParser parser = CSVFormat.EXCEL.parse(reader); for (CSVRecord record : parser.getRecords()) { System.out.println(record); } parser.close(); } /** * Defining a header manually */ @Test public void testParseWithHeader() throws Exception { Reader reader = new FileReader('C:/Users/Administrator/Desktop/abc.csv'); CSVParser parser = CSVFormat.EXCEL.withHeader('id', 'name', 'code').parse(reader); for (CSVRecord record : parser.getRecords()) { System.out.println(record.get('id') + ',' + record.get('name') + ',' + record.get('code')); } parser.close(); } /** * Using an enum to define a header */ enum MyHeaderEnum { ID, NAME, CODE; } @Test public void testParseWithEnum() throws Exception { Reader reader = new FileReader('C:/Users/Administrator/Desktop/abc.csv'); CSVParser parser = CSVFormat.EXCEL.withHeader(MyHeaderEnum.class).parse(reader); for (CSVRecord record : parser.getRecords()) { System.out.println(record.get(MyHeaderEnum.ID) + ',' + record.get(MyHeaderEnum.NAME) + ',' + record.get(MyHeaderEnum.CODE)); } parser.close(); } private List<Map<String, String>> recordList = new ArrayList<>(); @Before public void init() { for (int i = 0; i < 5; i++) { Map<String, String> map = new HashMap<>(); map.put('name', 'zhangsan'); map.put('code', '001'); recordList.add(map); } } @Test public void writeMuti() throws InterruptedException { ExecutorService executorService = Executors.newFixedThreadPool(3); CountDownLatch doneSignal = new CountDownLatch(2); executorService.submit(new exprotThread('E:/0.csv', recordList, doneSignal)); executorService.submit(new exprotThread('E:/1.csv', recordList, doneSignal)); doneSignal.await(); System.out.println('Finish!!!'); } class exprotThread implements Runnable { private String filename; private List<Map<String, String>> list; private CountDownLatch countDownLatch; public exprotThread(String filename, List<Map<String, String>> list, CountDownLatch countDownLatch) { this.filename = filename; this.list = list; this.countDownLatch = countDownLatch; } @Override public void run() { try { CSVPrinter printer = new CSVPrinter(new FileWriter(filename), CSVFormat.EXCEL.withHeader('NAME', 'CODE')); for (Map<String, String> map : list) { printer.printRecord(map.values()); } printer.close(); countDownLatch.countDown(); } catch (IOException e) { e.printStackTrace(); } } }

CSV與EXCEL

/** * 測試寫100萬數據需要花費多長時間 */ @Test public void testMillion() throws Exception { int times = 10000 * 10; Object[] cells = {'滿100減15元', '100011', 15}; // 導出為CSV文件 long t1 = System.currentTimeMillis(); FileWriter writer = new FileWriter('G:/test1.csv'); CSVPrinter printer = CSVFormat.EXCEL.print(writer); for (int i = 0; i < times; i++) { printer.printRecord(cells); } printer.flush(); printer.close(); long t2 = System.currentTimeMillis(); System.out.println('CSV: ' + (t2 - t1)); // 導出為Excel文件 long t3 = System.currentTimeMillis(); XSSFWorkbook workbook = new XSSFWorkbook(); XSSFSheet sheet = workbook.createSheet(); for (int i = 0; i < times; i++) { XSSFRow row = sheet.createRow(i); for (int j = 0; j < cells.length; j++) { XSSFCell cell = row.createCell(j); cell.setCellValue(String.valueOf(cells[j])); } } FileOutputStream fos = new FileOutputStream('G:/test2.xlsx'); workbook.write(fos); fos.flush(); fos.close(); long t4 = System.currentTimeMillis(); System.out.println('Excel: ' + (t4 - t3)); }

Maven依賴

<dependencies> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-csv</artifactId> <version>1.5</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.17</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.17</version> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency></dependencies>

最后,剛才的例子中只寫了3個字段,100萬行,生成的CSV文件有十幾二十兆,太多的話建議分多個文件打包下周,不然想象一個打開一個幾百兆的excel都費勁。

以上就是JAVA導出CSV文件實例教程的詳細內容,更多關于JAVA導出CSV文件的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 土壤水分自动监测站-SM150便携式土壤水分仪-铭奥仪器 | 塑钢课桌椅、学生课桌椅、课桌椅厂家-学仕教育设备首页 | 无纺布包装机|径向缠绕包装机|缠绕膜打包机-上海晏陵智能设备有限公司 | 游泳池设备安装工程_恒温泳池设备_儿童游泳池设备厂家_游泳池水处理设备-东莞市君达泳池设备有限公司 | 玻纤土工格栅_钢塑格栅_PP焊接_单双向塑料土工格栅_复合防裂布厂家_山东大庚工程材料科技有限公司 | pbt头梳丝_牙刷丝_尼龙毛刷丝_PP塑料纤维合成毛丝定制厂_广州明旺 | 家德利门业,家居安全门,别墅大门 - 安徽家德利门业有限公司 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 中高频感应加热设备|高频淬火设备|超音频感应加热电源|不锈钢管光亮退火机|真空管烤消设备 - 郑州蓝硕工业炉设备有限公司 | 四川职高信息网-初高中、大专、职业技术学校招生信息网 | 求是网 - 思想建党 理论强党 | 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 水稻烘干机,小麦烘干机,大豆烘干机,玉米烘干机,粮食烘干机_巩义市锦华粮食烘干机械制造有限公司 水环真空泵厂家,2bv真空泵,2be真空泵-淄博真空设备厂 | 宿舍管理系统_智慧园区系统_房屋/房产管理系统_公寓管理系统 | 超声波焊接机_超音波熔接机_超声波塑焊机十大品牌_塑料超声波焊接设备厂家 | 微信小程序定制,广州app公众号商城网站开发公司-广东锋火 | 脱硝喷枪-氨水喷枪-尿素喷枪-河北思凯淋环保科技有限公司 | 粉末包装机-给袋式包装机-全自动包装机-颗粒-液体-食品-酱腌菜包装机生产线【润立机械】 | 口信网(kousing.com) - 行业资讯_行业展会_行业培训_行业资料 | 天然鹅卵石滤料厂家-锰砂滤料-石英砂滤料-巩义东枫净水 | 便民信息网_家电维修,家电清洗,开锁换锁,本地家政公司 | 导电银胶_LED封装导电银胶_半导体封装导电胶厂家-上海腾烁 | 即用型透析袋,透析袋夹子,药敏纸片,L型涂布棒-上海桥星贸易有限公司 | 有福网(yofus.com)洗照片冲印,毕业聚会纪念册相册制作个性DIY平台 | 广州昊至泉水上乐园设备有限公司 | 锂电叉车,电动叉车_厂家-山东博峻智能科技有限公司 | 南京技嘉环保科技有限公司-杀菌除臭剂|污水|垃圾|厕所|橡胶厂|化工厂|铸造厂除臭剂 | 书信之家_书信标准模板范文大全 最新范文网_实用的精品范文美文网 | 磁力反应釜,高压釜,实验室反应釜,高温高压反应釜-威海自控反应釜有限公司 | 压缩空气检测_气体_水质找上海京工-服务专业、价格合理 | 不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰]-不锈钢法兰-碳钢法兰-法兰盘生产加工厂家-[鼎捷峰] | 闪蒸干燥机-喷雾干燥机-带式干燥机-桨叶干燥机-[常州佳一干燥设备] | Trimos测长机_测高仪_TESA_mahr,WYLER水平仪,PWB对刀仪-德瑞华测量技术(苏州)有限公司 | 超高频感应加热设备_高频感应电源厂家_CCD视觉检测设备_振动盘视觉检测设备_深圳雨滴科技-深圳市雨滴科技有限公司 | 商用绞肉机-熟肉切片机-冻肉切丁机-猪肉开条机 - 广州市正盈机械设备有限公司 | 纯化水设备-纯水设备-超纯水设备-[大鹏水处理]纯水设备一站式服务商-东莞市大鹏水处理科技有限公司 | LED灯杆屏_LED广告机_户外LED广告机_智慧灯杆_智慧路灯-太龙智显科技(深圳)有限公司 | 济南冷库安装-山东冷库设计|建造|冷库维修-山东齐雪制冷设备有限公司 | 台湾HIWIN上银直线模组|导轨滑块|TBI滚珠丝杆丝杠-深圳汉工 | 工控机-工业平板电脑-研华工控机-研越无风扇嵌入式box工控机 |