今天用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格式写入新文本中。
功能:利用流方式以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());// 中a
while (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);
}
}