Java讀取CSV文件(CSV文件數(shù)據(jù)內(nèi)容包含逗號(hào)處理)

最近在公司寫項(xiàng)目時(shí)悼凑,有個(gè)導(dǎo)入csv格式文件數(shù)據(jù)的需求违帆。Java讀取csv文件時(shí)默認(rèn)是按照?,[英文逗號(hào)]分割的涧偷,若是數(shù)據(jù)內(nèi)容不包含逗號(hào)的話就簡單多了潭流,但遇到的問題就恰巧是尷尬的地方。

如果你看到這篇文章试溯,應(yīng)該也是遇到相同的問題了吧

1.1 解決方案一(推薦)

pom.xml

<dependency>?

?????<groupId>com.opencsv</groupId>?

?????<artifactId>opencsv</artifactId>

?????<version>4.4</version>

</dependency>


1.2 代碼示例

public void readCSV() {

? ? ? ? String srcPath = "D:\\data\\line.csv";

? ? ? ? String charset = "utf-8";

? ? ? ? try (CSVReader csvReader = new CSVReaderBuilder(new BufferedReader(new InputStreamReader(new FileInputStream(new File(srcPath)), charset))).build()) {

? ? ? ? ? ? Iterator<String[]> iterator = csvReader.iterator();

? ? ? ? ? ? while (iterator.hasNext()) {

? ? ? ? ? ? ? ? Arrays.stream(iterator.next()).forEach(System.out::print);

? ? ? ? ? ? ? ? System.out.println();

? ? ? ? ? ? }

? ? ? ? } catch (Exception e) {

? ? ? ? ? ? e.printStackTrace();

? ? ? ? }

? ? }


2.1 解決方案二

看到的文章中蔑滓,覺得比較好的解決方案就是使用正則進(jìn)行匹配,讀取的csv數(shù)據(jù)默認(rèn)是用雙引號(hào)包起來的遇绞,在最后的截取中键袱,如果只按照雙引號(hào)外的逗號(hào)截取,不就是能得到想要的數(shù)據(jù)了摹闽。

2.1 代碼片段

/**

? * @param srcPath? csv文件路徑

? */

private void readCSVFileData(String srcPath) {


? ? ? ? BufferedReader reader = null;

? ? ? ? String line = null;

? ? ? ? try {

? ? ? ? ? ? reader = new BufferedReader(new FileReader(srcPath));

? ? ? ? } catch (FileNotFoundException e) {

? ? ? ? ? ? logger.error("[讀取CSV文件蹄咖,插入數(shù)據(jù)時(shí),讀取文件異常]");

? ? ? ? ? ? e.printStackTrace();

? ? ? ? }

? ? ? ? String[] fieldsArr = null;

? ? ? ? int lineNum = 0;

? ? ? ? int insertResult = 0;

? ? ? ? TableInfo tableInfo = new TableInfo();

? ? ? ? tableInfo.setTableName(tableName);

? ? ? ? try {

? ? ? ? ? ? List listField;

? ? ? ? ? ? while ((line = reader.readLine()) != null) {

? ? ? ? ? ? ? ? if (lineNum == 0) {

? ? ? ? ? ? ? ? ? ? //表頭信息

? ? ? ? ? ? ? ? ? ? fieldsArr = line.split(",");

? ? ? ? ? ? ? ? } else {

? ? ? ? ? ? ? ? ? ? //數(shù)據(jù)信息

? ? ? ? ? ? ? ? ? ? listField = new ArrayList<>();

? ? ? ? ? ? ? ? ? ? String str;


? ? ? ? ? ? ? ? ? ? line += ",";? ? ? ? ? ? ?

? ? ? ? ? ? ? ? ? ? Pattern pCells = Pattern

? ? ? ? ? ? ? ? ? ? ? ? ? ? .compile("(\"[^\"]*(\"{2})*[^\"]*\")*[^,]*,");

? ? ? ? ? ? ? ? ? ? Matcher mCells = pCells.matcher(line);

? ? ? ? ? ? ? ? ? ? List cells = new LinkedList();//每行記錄一個(gè)list

? ? ? ? ? ? ? ? ? ? //讀取每個(gè)單元格

? ? ? ? ? ? ? ? ? ? while (mCells.find()) {

? ? ? ? ? ? ? ? ? ? ? ? str = mCells.group();

? ? ? ? ? ? ? ? ? ? ? ? str = str.replaceAll(

? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? "(?sm)\"?([^\"]*(\"{2})*[^\"]*)\"?.*,", "$1");

? ? ? ? ? ? ? ? ? ? ? ? str = str.replaceAll("(?sm)(\"(\"))", "$2");

? ? ? ? ? ? ? ? ? ? ? ? cells.add(str);

? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? ? ? //從第2行起的數(shù)據(jù)信息list

? ? ? ? ? ? ? ? ? ? listField.add(cells);

? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? lineNum++;

? ? ? ? ? ? }


? ? ? ? } catch (Exception e) {

? ? ? ? ? ? e.printStackTrace();? ?

? ? ? ? }

? ? }

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末付鹿,一起剝皮案震驚了整個(gè)濱河市澜汤,隨后出現(xiàn)的幾起案子铝量,更是在濱河造成了極大的恐慌,老刑警劉巖银亲,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件慢叨,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡务蝠,警方通過查閱死者的電腦和手機(jī)拍谐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來馏段,“玉大人轩拨,你說我怎么就攤上這事≡合玻” “怎么了亡蓉?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長喷舀。 經(jīng)常有香客問我砍濒,道長,這世上最難降的妖魔是什么硫麻? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任爸邢,我火速辦了婚禮,結(jié)果婚禮上拿愧,老公的妹妹穿的比我還像新娘杠河。我一直安慰自己,他們只是感情好浇辜,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布券敌。 她就那樣靜靜地躺著,像睡著了一般柳洋。 火紅的嫁衣襯著肌膚如雪待诅。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天膳灶,我揣著相機(jī)與錄音咱士,去河邊找鬼。 笑死轧钓,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的锐膜。 我是一名探鬼主播毕箍,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼道盏!你這毒婦竟也來了而柑?” 一聲冷哼從身側(cè)響起文捶,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎媒咳,沒想到半個(gè)月后粹排,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡涩澡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年顽耳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片妙同。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡射富,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出粥帚,到底是詐尸還是另有隱情胰耗,我是刑警寧澤,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布芒涡,位于F島的核電站柴灯,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏费尽。R本人自食惡果不足惜弛槐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望依啰。 院中可真熱鬧乎串,春花似錦、人聲如沸速警。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽闷旧。三九已至长豁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間忙灼,已是汗流浹背匠襟。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留该园,地道東北人酸舍。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像里初,于是被迫代替她去往敵國和親啃勉。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容

  • 一双妨、基礎(chǔ)知識(shí):1淮阐、JVM叮阅、JRE和JDK的區(qū)別:JVM(Java Virtual Machine):java虛擬機(jī)...
    殺小賊閱讀 2,365評(píng)論 0 4
  • pyspark.sql模塊 模塊上下文 Spark SQL和DataFrames的重要類: pyspark.sql...
    mpro閱讀 9,446評(píng)論 0 13
  • 小編費(fèi)力收集:給你想要的面試集合 1.C++或Java中的異常處理機(jī)制的簡單原理和應(yīng)用。 當(dāng)JAVA程序違反了JA...
    八爺君閱讀 4,574評(píng)論 1 114
  • 一. Java基礎(chǔ)部分.................................................
    wy_sure閱讀 3,795評(píng)論 0 11
  • 50道經(jīng)典Java編程練習(xí)題泣特,將數(shù)學(xué)思維運(yùn)用到編程中來浩姥。抱歉哈找不到文章的原貼了,有冒犯的麻煩知會(huì)聲哈~ 1.指數(shù)...
    OSET我要編程閱讀 6,947評(píng)論 0 9