gpt4 book ai didi

java - 使用java - 文本字段中的逗号分隔符读取csv文件

转载 作者:行者123 更新时间:2023-12-01 17:34:11 27 4
gpt4 key购买 nike

我有一个逗号分隔的 CSV 文件,其中包含 NASDAQ 符号。我使用扫描仪读取文件

  s = new Scanner(new File("C:\\nasdaq_companylist.csv")).useDelimiter("\\s*,\\s*");    

我在第二个字段上遇到异常。问题是该字段与文件中的其他一些字段一样也包含逗号,例如“1-800 FLOWERS.COM, Inc.”:

FLWS,"1-800 FLOWERS.COM, Inc.",2.8,76022800,n/a,1999,Consumer Services,Other Specialty Stores,http://www.nasdaq.com/symbol/flws    

如何避免这个问题?我的代码是:

List<Stock> theList = new ArrayList<Stock>();
StringBuilder sb = new StringBuilder();

//get the title
String title = s.nextLine();
System.out.println("title: "+title);

while (s.hasNext())
{

String symbol = s.next();
String name = s.next();
double lastSale = s.nextDouble();
long marketCap = s.nextLong();
String adr =s.next();
String ipoYear=s.next();
String sector=s.next();
String industry = s.next();
String summaryQuote = s.next();
theList.add(newStock(symbol,lastSale));}

谢谢

最佳答案

除非这是家庭作业,否则您不应该自己解析 CSV。使用现有库之一。例如这个:http://commons.apache.org/sandbox/csv/

或者谷歌“java csv parser”并选择另一个。

但是,如果您希望自己实现逻辑,则应该使用正则表达式的负向先行功能(请参阅 http://download.oracle.com/javase/1,5.0/docs/api/java/util/regex/Pattern.html )

关于java - 使用java - 文本字段中的逗号分隔符读取csv文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8034820/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com