I’ve two questions:
Is there a way through which we can open a xls file and save it as a tsv file through Java?
EDIT:
Or is there a way through which we can convert a xls file into an tsv file through Java?
Is there a way in which we can convert a UTF-16LE file to UTF-8 using java ?
Thank you
On StackOverflow you should split that into two different questions…
I’ll answer your second question:
Yes of course. And there’s more than one way.
Basically you want to read your input file specifying the input encoding (UTF-16LE) and then write the file specifying the output encoding (UTF-8).
Say you have some UTF-16LE encoded file:
You then basically could do something like this in Java (it’s just an example: you’ll want to fill in missing exception handling code, maybe not put a last newline at the end, maybe discard the BOM if any, etc.):
This shall create a UTF-8 encoded file.
The BOM can clearly be seen using, for example, hexdump:
The BOM is encoded on three bytes in UTF-8 (ef bb fb) while it’s encoded on two bytes in UTF-16. In UTF16-LE the BOM looks like this:
Note that UTF-8 encoded files may or may not (both are totally valid) have a “BOM” (byte order mask). A BOM in a UTF-8 file is not that silly: you don’t care about the byte order but it can help quickly identify a text file as being UTF-8 encoded. UTF-8 files with a BOM are fully legit according to the Unicode specs and hence readers unable to deal with UTF-8 files starting with a BOM are broken. Plain and simple.
If for whatever reason you’re working with broken UTF-8 readers unable to cope with BOMs, then you may want to remove the BOM from the first String before writing it to disk.
More infos on BOMs here:
http://unicode.org/faq/utf_bom.html