在命令行打印时,会将Unicode字符串打印到终端。终端有一个编码,所以Python将您的Unicode字符串编码为该编码。这样就行了。
当你在CGI中使用它时,你最终会打印到stdout,它没有编码。因此,Python尝试用ASCII编码字符串。这将失败,因为ASCII不包含您试图打印的所有字符,所以您将得到上述错误。
解决方法是将字符串编码成某种编码(为什么不是UTF8?)在标题中也这么说。
所以像这样:sys.stdout.buffer.write(b"Content-type: text/html;encoding=UTF-8\n\n") # Not 100% sure about the spelling.
sys.stdout.buffer.write(site.encode('UTF8'))
在Python 2下,这也可以工作:print("Content-type: text/html;encoding=UTF-8\n\n") # Not 100% sure about the spelling.
print(site.encode('UTF8'))
但是在Python 3中,编码的数据是以字节为单位的,因此它不会很好地打印。
当然,您会注意到,您现在首先从UTF8解码,然后重新编码。严格地说,你不需要那么做。但是,如果您希望在两者之间修改HTML,那么最好这样做,并将所有修改保持为Unicode格式。