Uza*_*ooq 10 java csv readline filereader
我正在阅读从谷歌趋势下载的CSV文件,这里是在记事本中打开时的文件内容(仅前两行):
法拉利法拉利(标准误差)
0.735 2%
当我使用readline读取文件时,行读取包含每个字符之间的空格,在上面的例子中,输出是:
ferrariferrari(stderror)
0.7 3 5 2%
("法拉利"和"法拉利"之间有标签,介于0.735和2%之间,没有显示堆叠溢出)
每行末尾的换行符也会被读取两次.为什么会这样?有解决方案吗
这是我用来读取文件的代码:
BufferedReader Reader = new BufferedReader(new FileReader("trend.csv"));
String line = null;
while ((line = Reader.readLine()) != null)
System.out.println(line);
Run Code Online (Sandbox Code Playgroud)
编辑:在文件的开头还有一些奇怪的字符
Edut:得到了解决方案
这是编码问题,将第一行改为:
BufferedReader Reader = new BufferedReader(new InputStreamReader(new FileInputStream("trend.csv"), "UTF-16"));
Run Code Online (Sandbox Code Playgroud)
San*_*adi 15
这是由于字符编码...我刚刚从趋势下载文件并尝试过,它有同样的问题.
如果我使用UTF-16字符集,我就可以解决这个问题.
public class TrendReader
{
public static void main(String args[]) throws Exception
{
//BufferedReader Reader = new BufferedReader(new FileReader("trends.csv"));
BufferedReader Reader = new BufferedReader(new InputStreamReader(new FileInputStream("trends.csv"), "UTF-16"));
String line = null;
while ((line = Reader.readLine()) != null)
{
System.out.println(line);
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7668 次 |
| 最近记录: |