关于UTF16转成普通的UTF8文本
今天用PL/SQL导入数据的时候遇到无法导入,提示UTF16 detected,this is not yet supported by the importer。另外换sqluldr导入数据后发现数据全部为null,看来确实是UTF16格式不支持在我的ORACLE9i数据库中。无奈只得处理下,有一个比较简单方法是用editplus打开后复制一份到新文本中,这样新文本的数据就会和系统一致。另外一个方法自然是写个简单代码直接从UTF16转到UTF8。以下代码我借鉴了网上一些资料后自己写了,里面还有一些未知bug,但是自己现在暂时用来转换整数号码文本没有问题,以后有时间再进一步改进。
功能:利用流方式以UTF16格式读取源UTF16文本中每一行后添加到StringBuffer中,再将StringBuffer以UTF8格式写入新文本中。
package test;import java.io.BufferedReader;import java.io.File;import java.io.FileInputStream;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStreamReader;import java.io.OutputStreamWriter;public class Utf16ToUtf8 {private int count = 0;public void Utf16RedWrite(String filePath1,String filePath2) {StringBuffer buffer = new StringBuffer();try {// --读BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(filePath1), "UTF-16"));// System.out.println(br.readLine());// 中awhile (br.ready()) {buffer.append(br.readLine());buffer.append("\n");count++;}// --正确的字符流写OutputStreamWriter ow = new OutputStreamWriter(new FileOutputStream(filePath2), "UTF-8");ow.write(buffer.toString());ow.close();br.close();} catch (IOException e) {e.printStackTrace();}}public static void main (String args[]){Utf16ToUtf8 utu = new Utf16ToUtf8();String f1 = "E:/sql_loader/sqlload_watone/20110522.txt";String f2 = "E:/sql_loader/sqlload_watone/20110522_1.txt";utu.Utf16RedWrite(f1,f2);}}