<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
            java語言

            java讀取CSV的方法

            時間:2025-04-04 08:47:50 java語言 我要投稿

            java讀取CSV的方法大全

              【提要】本篇《java讀取CSV的方法》特別為需要方法編程學習的朋友收集整理的,僅供參考。內容如下:

              在項目開發中,我們經常需要讀取csv的內容的操作。讀取的邏輯并不復雜。以下是小編為大家搜索整理的java讀取CSV的方法,希望能給大家帶來幫助!更多精彩內容請及時關注我們考試網!

              Csv文件,逗號分隔的常用數據文件格式,默認可以用Office軟件打開。

              看項目中以前的處理方式是直接用用java IO類庫讀取Csv文件,實際處理中發現Csv文件本身包含了對各種特殊字符的處理信息。最常見的比如:

              1. 對包含特殊字符的字符串數據首尾加雙引號

              2. 對數據中的單個雙引號前加單個雙引號

              其它...

              所以用Java IO讀到的字符串全是經過處理后的字符串,在某些場景下是不符合預期需求的。比如我需要的是不做任何處理的原始內容。

              項目中另一種常見的文件格式Excel用了POI來處理,但是POI不支持Csv格式,于是找到了javacsv。

              代碼很簡單:

              Java代碼

              public List importCsv(String file) {

              List list = new ArrayList();

              CsvReader reader = null;

              try {

              //初始化CsvReader并指定列分隔符和字符編碼

              reader = new CsvReader(file, ,, Charset.forName("GBK"));

              while (reader.readRecord()) {

              //讀取每行數據以數組形式返回

              String[] str = reader.getValues();

              if (str != null && str.length > 0) {

              if (str[0] != null && !"".equals(str[0].trim())) {

              list.add(str);

              }

              }

              }

              } catch (FileNotFoundException e) {

              log.error("Error reading csv file.",e);

              } catch (IOException e) {

              log.error("",e);

              }

              finally{

              if(reader != null)

              //關閉CsvReader

              reader.close();

              }

              return list;

              }

              以上代碼有幾個要點:

              1 初始化CsvReader時指定分隔符和字符編碼,如果不指定,默認分別為逗號和ISO-8859-1,我用了GBK,具體使用時要看當時的字符編碼而定。

              2 讀取每行數據,返回字符串數組,數組內的順序即文件數據列的順序

              3 最后記得關閉CsvReader

              是不是很簡單,返回的數組格式也正好是我想要的,而且拿到是原始的數據,沒有經過特殊字符處理。

              有些童鞋質疑特殊字符未經處理,插到數據庫會出錯,其實大可不必我們手工處理,一些基礎組件比如JDBC的preparedstatement已經包含了對特殊字符的處理,我們只要以綁定參數的形式來傳送這些包含特殊字符的數據就可以。常用的持久化框架底層也封裝了JDBC,自然也對特殊字符做了處理。

            【java讀取CSV的方法】相關文章:

            java讀取CSV的方法06-10

            java如何讀取CSV06-26

            Java讀取郵件的方法10-03

            Java讀取郵件的方法有哪些05-31

            講述java讀取properties文件的方法08-13

            php使用fgetcsv讀取csv文件出現亂碼的解決方法10-22

            從Java的jar文件中讀取數據的方法08-24

            Java的jar文件中讀取數據的方法09-27

            php使用fgetcsv讀取csv文件出現亂碼09-23

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院