IronPython 中文乱码问题

最近在研究umbraco,这是一款.net下比较强大的CMS,灵活性很高,支持XSLT ,UserControl,IronPython等,在应用IronPython作为宏的时候,发现不支持中文,经过研究后,这不是umbraco的问题,而IronPython本身的问题。据说是IronPython支持多国编码的。可以应用如下方式

import sys

sys.setdefaultencoding('GB2312')

b="中国"

print b

遗憾的事,事情不像想象地那么美好。网上还有介绍u”中国”,abc.encode之类的方法,好象不管用。后来,看了IronPython(1.1)的源码,发现在SystemState中的Initialize方法里有这么一句。DefaultEncoding = Encoding.ASCII; 按理说DefaultEncoding是可以通过sys.setdefaultencoding进行赋值变更的,但经测试后,好像不行。由于时间的关系没用继续研究下去。解决问题就返回来了。具体的方法如下:

(1)将DefaultEncoding = Encoding.ASCII;修改为

DefaultEncoding = Encoding.GetEncoding("GB2312");

(2) Parser.cs中的FromFile中的Encoding.ASCII编码改为Encoding.GetEncoding("GB2312");

重编译后,无论是代码脚本还是从文件脚本均可以正常

test.py文件内容

b="上海"
print b

测试代码

IronPython.Hosting.PythonEngine pe = new IronPython.Hosting.PythonEngine();

MemoryStream sout = new MemoryStream();

pe.SetStandardOutput(sout);

pe.Execute("print \"中国\"");

pe.ExecuteFile("c:\\temp\\script\\test.py");

string result = Encoding.GetEncoding("GB2312").GetString(sout.ToArray());

System.Console.WriteLine(result);

你可能感兴趣的:(C++,c,cms,.net,脚本)