本文目錄一覽:
java實現把csv文件導入到sqlserver
可以通過BufferedReader
流的形式進行流緩存,之後通過readLine方法獲取到緩存的內容。
BufferedReader
bre
=
null;
try
{
String
file
=
“D:/test/test.txt”;
bre
=
new
BufferedReader(new
FileReader(file));//此時獲取到的bre就是整個文件的緩存流
while
((str
=
bre.readLine())!=
null)
//
判斷最後一行不存在,為空結束循環
{
String
item[]
=
bre.split(“,”);//CSV格式文件為逗號分隔符文件,這裡根據逗號切分
String
last
=
item[item.length-1];//通過此方法獲取到數據信息
//int
value
=
Integer.parseInt(last);//如果是數值,可以轉化為數值
System.out.println(last);//此處轉換成數據庫相應的語句即可實現存儲操作
};
備註:
流用完之後必須close掉,如上面的就應該是:bre.close(),否則bre流會一直存在,直到程序運行結束。
JAVA導入txt、CSV的例子
導入文件若為二進制格式的csv或xls文件需要用jxl.jar包來解析,若文件為文本格式逗號分隔的csv文件則需要用opencsv.jar包來解析。下面為導入兩種格式文件的代碼示例:1. 導入文本格式逗號分隔的csv文件Java代碼 import au.com.bytecode.opencsv.CSVReader; import au.com.bytecode.opencsv.CSVReader; Java代碼 public void importCsvFile() { CSVReader csvReader = null; try { csvReader = new CSVReader(new FileReader(importFile),’,’);//importFile為要導入的文本格式逗號分隔的csv文件,提供getXX/setXX方法 if(csvReader != null){ //first row is title, so past csvReader.readNext(); String[] csvRow = null;//row while ((csvRow = csvReader.readNext()) != null){ for (int i =0; icsvRow.length; i++){ String temp = csvRow[i]; switch (i) { case 0: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanName(temp); } break; case 1: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanEmail(temp); } break; default: break; } } //保存linkman到數據庫 if(linkman.getLinkmanName() != null linkman.getLinkmanEmail() != null){ EmailLinkmanAPI.insertLinkman(linkman); } } } } catch (Exception e) { e.printStackTrace(); } } public void importCsvFile() { CSVReader csvReader = null; try { csvReader = new CSVReader(new FileReader(importFile),’,’);//importFile為要導入的文本格式逗號分隔的csv文件,提供getXX/setXX方法 if(csvReader != null){ //first row is title, so past csvReader.readNext(); String[] csvRow = null;//row while ((csvRow = csvReader.readNext()) != null){ for (int i =0; icsvRow.length; i++){ String temp = csvRow[i]; switch (i) { case 0: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanName(temp); } break; case 1: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanEmail(temp); } break; default: break; } } //保存linkman到數據庫 if(linkman.getLinkmanName() != null linkman.getLinkmanEmail() != null){ EmailLinkmanAPI.insertLinkman(linkman); } } } } catch (Exception e) { e.printStackTrace(); } }2. 二進制格式的csv或xls文件Java代碼 import jxl.Sheet; import jxl.Workbook; import jxl.Sheet; import jxl.Workbook; Java代碼 public void importXlsFile() { Workbook book = null; try { book = Workbook.getWorkbook(importFile);//importFile為要導入的xls文件,或二進制的csv文件,提供getXX/setXX方法 } catch (Exception e) { e.printStackTrace(); } if(book != null){ int sheetNo = book.getNumberOfSheets(); for(int i = 0; i sheetNo; i++){ Sheet sheet=book.getSheet(i); int rowNum = sheet.getRows(); int colNum = sheet.getColumns(); //first row is title, so past for(int r = 1; r rowNum; r++){//行 for(int c = 0; c colNum;c++){//列 String temp = sheet.getCell(c,r).getContents(); switch (c) { case 0: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanName(temp); } break; case 1: if(StringUtils.isNotEmpty(temp)){ linkman.setLinkmanEmail(temp); } break; default: break; } } //保存linkman到數據庫 if(linkman.getLinkmanName() != null linkman.getLinkmanEmail() != null){ EmailLinkmanAPI.insertLinkman(linkman); } } } } }
求個java讀取csv文件並輸出的程序
要使用CsvReader,CsvWriter需要下載一個javacsv.jar導入到項目中
package test;import com.csvreader.CsvReader;import com.csvreader.CsvWriter;import java.io.BufferedReader; import java.io.BufferedWriter;import java.io.File; import java.io.FileNotFoundException; import java.io.FileReader; import java.io.FileWriter;import java.io.IOException; public class readandwrite { public static void main(String[] args) throws IOException { String [] str ={“省”,”市”,”區”,”街”,”路”,”里”,”幢”,”村”,”室”,”園”,”苑”,”巷”,”號”}; String inString = “”; String tmpString = “”; File inFile = new File(“C://in.csv”); // 讀取的CSV文件 File outFile = new File(“C://outtest.csv”);//輸出的CSV文 try { BufferedReader reader = new BufferedReader(new FileReader(inFile)); BufferedWriter writer = new BufferedWriter(new FileWriter(outFile)); CsvReader creader = new CsvReader(reader, ‘,’); CsvWriter cwriter = new CsvWriter(writer,’,’); while(creader.readRecord()){ inString = creader.getRawRecord();//讀取一行數據 for(int i = 0;i str.length;i++){ tmpString = inString.replace(str[i], “,” + str[i] + “,”); inString = tmpString; } //第一個參數表示要寫入的字符串數組,每一個元素佔一個單元格,第二個參數為true時表示寫完數據後自動換行 cwriter.writeRecord(inString.split(“,”), true); //注意,此時再用cwriter.write(inString)方法寫入數據將會看到只往第一個單元格寫入了數據,「,」沒起到調到下一個單元格的作用 //如果用cwriter.write(String str)方法來寫數據,則要用cwriter.endRecord()方法來實現換行 //cwriter.endRecord();//換行 cwriter.flush();//刷新數據 } creader.close(); cwriter.close(); } catch (FileNotFoundException ex) { ex.printStackTrace(); } }}
java里將從excel讀到的數據用csv導出,代碼怎麼寫
解釋:csv文件實際上就是字符串,之間用「,」進行分割,之後進行的存儲。
工具類如下:
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.util.List;
/**
*
* CSV文件導出工具類
*/
public class CSVUtils {
/**
* CSV文件生成方法
* @param head
* @param dataList
* @param outPutPath
* @param filename
* @return
*/
public static File createCSVFile(List head, ListList dataList,
String outPutPath, String filename) {
File csvFile = null;
BufferedWriter csvWtriter = null;
try {
csvFile = new File(outPutPath + File.separator + filename + “.csv”);
File parent = csvFile.getParentFile();
if (parent != null !parent.exists()) {
parent.mkdirs();
}
csvFile.createNewFile();
// GB2312使正確讀取分隔符”,”
csvWtriter = new BufferedWriter(new OutputStreamWriter(new FileOutputStream(
csvFile), “GB2312”), 1024);
// 寫入文件頭部
writeRow(head, csvWtriter);
// 寫入文件內容
for (List row : dataList) {
writeRow(row, csvWtriter);
}
csvWtriter.flush();
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
csvWtriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
return csvFile;
}
/**
* 寫一行數據方法
* @param row
* @param csvWriter
* @throws IOException
*/
private static void writeRow(List row, BufferedWriter csvWriter) throws IOException {
// 寫入文件頭部
for (Object data : row) {
StringBuffer sb = new StringBuffer();
String rowStr = sb.append(“\””).append(data).append(“\”,”).toString();
csvWriter.write(rowStr);
}
csvWriter.newLine();
}
}
Object-Z
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/159767.html