以前,我有一个代码如下:
Writer writer = new OutputStreamWriter(System.out, "UTF-8");
generator.stream(writer);
现在,我的代码如下所示:
string = new StringBuilder();
OutputStream output = new OutputStream()
{
public String getString()
{
return string.toString();
}
@Override
public void write(int b) throws IOException {
if ((char)b != '\n')
{
string.append((char) b );
}
}
public String toString(){
return string.toString();
}
};
Writer writer = new OutputStreamWriter(output, "UTF-8");
generator.stream(writer);
writer.close();
PrintStream ps = new PrintStream(System.out, true, "UTF-8");
ps.println(string.toString());
第一个代码的问题是它不能保证输出在一行中。另一方面,我的新代码解决了这个问题,然而,出现了一个新问题:输出发送'ㅐチ'而不是'Á',这是非常痛苦的,因为应该支持匈牙利语和波兰语字符。对于非匈牙利语,非波兰语字符,我当前的输出是正确的,但我的新代码不处理书面匈牙利语和波兰语中的特殊字符。我怎样才能克服这个问题?
感谢。
答案 0 :(得分:3)
扩展OutputStreamWriter类并覆盖相应的方法以删除换行符。
public class NoNewLineOutputStreamWriter extends OutputStreamWriter {
public NoNewLineOutputStreamWriter(OutputStream out,String charset) throws UnsupportedEncodingException {
super(out,charset);
}
public void write(String str) throws IOException {
super.write(str.replaceAll("\n", ""));
};
public void write(int c) {
if (c == '\n')
return;
else
super.write(c);
}
}
然后像以前一样打电话给你的作家
Writer writer = new NoNewLineOutputStreamWriter(System.out, "UTF-8");
generator.stream(writer);
答案 1 :(得分:0)
这必须是因为操作系统的默认字符集。
我有类似的问题关于é转换成Ã。
我将JVM file.encoding更改为UTF -Dfile.encoding=UTF-8
。
然后我的问题就解决了。
请阅读此内容: