在java中读取CSV文件会在每个字符之间添加空格

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)