奶头挺立呻吟高潮av全片,成人试看120秒体验区,性欧美极品v,A片高潮抽搐揉捏奶头视频

java語言

java如何讀取CSV

時間:2024-06-26 17:37:59 java語言 我要投稿
  • 相關推薦

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讀取CSV的方法大全09-12

如何利用java讀取網絡照片10-16

Java如何讀取文本文件07-06

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

從Java的jar文件中如何讀取數據的方法10-18

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

Java讀取圖片EXIF信息的代碼08-27

Java如何正則表達式分析讀取網頁內容06-29

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

主站蜘蛛池模板: 和田县| 大连市| 乐山市| 台山市| 卢龙县| 永康市| 沅江市| 吉隆县| 乌拉特后旗| 汶川县| 民和| 怀柔区| 宁安市| 通城县| 东兰县| 九龙坡区| 乐至县| 镇雄县| 合川市| 南靖县| 金山区| 稷山县| 永宁县| 秦安县| 韩城市| 双流县| 垦利县| 巴林左旗| 呼和浩特市| 固安县| 石柱| 井研县| 静乐县| 澄城县| 克东县| 天峻县| 宣汉县| 南汇区| 兴化市| 西丰县| 和田市|