Java
Java
Write utf-8 CSV Compatible with Excel
See more CSV Examples
A CSV containing non-English characters that is saved using the utf-8 character encoding must include a BOM (also known as a preamble) if it is to be correctly loaded into Excel. See https://en.wikipedia.org/wiki/Byte_order_markThis example shows how to save the CSV to a file using utf-8 with a BOM.
Note: This example requires Chilkat v9.5.0.93 or later.
Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// This example program loads a file (japanese.csv)
// that contains this content:
//
// year,color,country,food
// 2001,red,France,cheese
// 2005,blue,"United States",hamburger
// 2008,green,Italy,pasta
// 1998,orange,Japan,sushi
// 2010,silver,"太志","森田"
//
CkCsv csv = new CkCsv();
csv.put_HasColumnNames(true);
success = csv.LoadFile2("qa_data/csv/test.csv","utf-8");
if (success != true) {
System.out.println(csv.lastErrorText());
return;
}
// To save the CSV using utf-8 with a BOM/preamble,
// add "EMIT_BOM" to the UncommonOptions.
// (This feature was added in Chilkat v9.5.0.93)
csv.put_UncommonOptions("EMIT_BOM");
success = csv.SaveFile2("qa_output/test.csv","utf-8");
if (success != true) {
System.out.println(csv.lastErrorText());
return;
}
System.out.println("OK, try to load the CSV in Excel to see if the non-English chars are correct.");
}
}