java导出数据到dbf文件,如果姓名中有生僻汉字,在dbf中看到的很可能是?号。
遇到这种情况需查对GBK的生僻汉字的Unicode表,GBK提及的52个生僻汉字有两种Unicode。例如:䶮(yan 3) \u4ADE就不能在dbf中正常显示是?,如果换成\uE863则可以(可以打开word的插入->符号->其他符号,在字符代码中输入4ADE的到字符插入word,输入E863的到另一形式插入word,将这两种形式的字符从word拷贝到Visual Fox Pro的命令窗口可以看到差别,一个变成?一个能正常显示)。
解决方式:
1.建立52个生僻汉字的unicode映射Map
2.将生僻汉字转成unicode形式(有可能是将整个姓名转成unicode)
3.将姓名的unicode形式进行分割(\u)生成数组(注意两端的双引号)
4.遍历unicode数组,如果找到生僻汉字的unicode则进行替换
5.将unicode还原成汉字
6.写入dbf
汉字转unicode可利用(import com.alibaba.fastjson.JSON) :
//unicode转中文
public static String unicodeToString(String str) {
return String.valueOf(JSON.parse(str));
}
//中文字符转unicode
public static String stringToUnicode(String s) {
return JSON.toJSONString(s, SerializerFeature.BrowserCompatible);
}
其他说明:
例如:
䶮在mysql中能显示出来,导出到dbf中时如果选择
字符集为
GB2312或GBK,导出的
䶮为?。
在Visual Fox Pro 9的命令窗口里输入的
䶮为?,
打开word,插入,输入字符编码4DAE得到
䶮,插入到word,复制粘贴到
Visual Fox Pro 9的命令窗口改字显示
为?
打开word,插入,输入字符编码8E63得到
,有些版本的Word能显示出来,有些版本的不能显示,按Alt+X
,插入到word,复制粘贴到
Visual Fox Pro 9的命令窗口改字能显示
正常
上图输入E863无反应
按快捷键Alt+x后的效果