1

当我将一个包含许多文件的文件夹从 ANSI(windows-1252) 转换为 UTF8 时,一些文件被截断,而一个小文件完全空白。我尝试通过减小缓冲区大小来转换文件,但没有成功。有人对此有任何想法吗???

public class ConvertFromAnsiToUtf8 {

private static final char BYTE_ORDER_MARK = '\uFEFF';
private static final String ANSI_CODE = "windows-1252";
private static final String UTF_CODE = "UTF8";
private static final Charset ANSI_CHARSET = Charset.forName(ANSI_CODE);

public static void main(String[] args) {

List<File> fileList;
File inputFolder = new File(args[0]);
if (!inputFolder.isDirectory()) {
    return;
}
File parentDir = new File(inputFolder.getParent() + "\\"
                + inputFolder.getName() + "_converted");

if (parentDir.exists()) {
    return;
}
if (parentDir.mkdir()) {

} else {
    return;
}

fileList = new ArrayList<File>();
for (final File fileEntry : inputFolder.listFiles()) {
    fileList.add(fileEntry);
}

InputStream in;
Reader reader = null;
Writer writer = null;
try {
    for (File file : fileList) {
        in = new FileInputStream(file.getAbsoluteFile());
        reader = new InputStreamReader(in, ANSI_CHARSET);

        OutputStream out = new FileOutputStream(
                        parentDir.getAbsoluteFile() + "\\"
                                        + file.getName());
        writer = new OutputStreamWriter(out, UTF_CODE);
        writer.write(BYTE_ORDER_MARK);
        char[] buffer = new char[10];
        int read;
        while ((read = reader.read(buffer)) != -1) {
            System.out.println(read);
            writer.write(buffer, 0, read);
        }
    }
    reader.close();
    writer.close();
} catch (FileNotFoundException e) {
    e.printStackTrace();
} catch (UnsupportedEncodingException e) {
    e.printStackTrace();
} catch (IOException e) {
    e.printStackTrace();
}
}
}

任何指针都会有所帮助。

谢谢,阿希什

4

0 回答 0