关于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);
		
	}
}


你可能感兴趣的:(java,sql)