关于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());// 中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);

}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值