【问题标题】:CSV header validation using supercsv使用 supercsv 验证 CSV 标头
【发布时间】:2013-01-21 01:31:19
【问题描述】:

如何验证 CSV 文件的数据是否包含标题?我正在使用 supercsv 和 Java。我的 csv 文件包含;

ACCOUNT,NAME,PHONE (header)

Saving,Carl,1234567891(数据)

感谢您的帮助。

【问题讨论】:

  • 欢迎来到 StackOverflow :) 正如@fge 所说,您确实应该记录您所尝试的内容。它使其他人更容易回答,并且您更有可能获得对您的问题的支持。

标签: java csv supercsv


【解决方案1】:

如果您事先不知道标头值是什么,则无法知道第一行是否是标头(它看起来就像另一条数据行)。

如果您确实知道标题值应该是什么,那么您可以简单地确保所有预期的列都在那里(顺序无关紧要,只要它们在那里)。

例如

List<String> expectedHeaders = Arrays.asList("ACCOUNT","NAME","PHONE");

String[] header = csvReader.getHeader(true);

if (!Arrays.asList(header).containsAll(expectedHeaders)){
    // not all headers present - handle appropriately 
    // (e.g. throw exception)
}

【讨论】:

  • 感谢猎犬的建议。
  • 没问题@Dharanae,别忘了选这个作为正确答案(如果是的话!)
猜你喜欢
  • 1970-01-01
  • 2016-06-06
  • 2019-03-13
  • 1970-01-01
  • 2021-09-11
  • 2012-11-18
  • 1970-01-01
  • 2016-05-29
  • 1970-01-01
相关资源
最近更新 更多