tom
tom

Reputation: 1223

how to read utf-8 chars in opencsv

I am trying to read from csv file. The file contains UTF-8 characters. So based on Parse CSV file containing a Unicode character using OpenCSV and How read Japanese fields from CSV file into java beans? I just wrote

CSVReader reader = new CSVReader(new InputStreamReader(new FileInputStream("data.csv"), "UTF-8"), ';');

But it does not work. The >>Sí, es nuevo<< text is visible correctly in Notepad, Excel and various other text editing tools, but when I parse the file via opencsv I'm getting >>S�, es nuevo<< ( The í is a special character if you were wondering ;)

What am I doing wrong?

Upvotes: 0

Views: 11617

Answers (4)

Gavin Sheng
Gavin Sheng

Reputation: 21

you can use encoder=UTF-16LE,I'm write a file for Japanese

Upvotes: 2

gurtell
gurtell

Reputation: 1

Use ISO-8859-1 or ISO-8859-14 or ISO-8859-15 or ISO-8859-10 or ISO-8859-13 or ISO-8859-2 instead of using UTF-8

Upvotes: 0

tom
tom

Reputation: 1223

Thanks aioobe. It turned out the file was not really UTF-8 despite most Win programs showing it as such. Notepad++ was the only one that did not show the file as UTF-8 encoded and after converting the data file the code works.

Upvotes: 1

Yash
Yash

Reputation: 1751

Use the below code for your issue it might helpful to you...

String value = URLEncoder.encode(msg[no], "UTF-8");

thanks, Yash

Upvotes: 0

Related Questions