当传递Python程序的输出的管道时,Python解释器对编码感到困惑,并将其设置为None。这意味着这样的程序:
# -*- coding: utf-8 -*-
print u"åäö"
正常运行时可以正常工作,但失败:
UnicodeEncodeError:'ascii'
编解码器无法在位置0
编码字符u'\ xa0'
:序数不在范围内(128)
以管道顺序使用时。
使管道工作的最佳方法是什么?我能告诉它使用外壳程序/文件系统/正在使用的任何编码吗?
到目前为止,我所看到的建议是直接修改你的site.py
,或使用此hack硬编码defaultencoding
:
# -*- coding: utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
print u"åäö"
有更好的方法使管道工作吗?
你的代码在脚本中运行时有效,因为Python会将输出编码为你的终端应用程序正在使用的任何编码。如果要进行管道传输,则必须自己对其进行编码。
经验法则是:始终在内部使用Unicode。解码收到的内容,并对发送的内容进行编码。
# -*- coding: utf-8 -*-
print u"åäö".encode('utf-8')
另一个教学示例是一个Python程序,该程序可以在ISO-8859-1和UTF-8之间进行转换,从而使两者之间都大写。
import sys
for line in sys.stdin:
# Decode what you receive:
line = line.decode('iso8859-1')
# Work with Unicode internally:
line = line.upper()
# Encode what you send:
line = line.encode('utf-8')
sys.stdout.write(line)
设置系统默认编码不是一个好主意,因为你使用的某些模块和库可能依赖于它是ASCII的事实。不要这样
我是Java的初学者。学习罗伯特·塞奇威克的《Java导论》 我尝试在Netbeans中编译以下代码。 } 我收到了这个错误。我已将文件放置在标准位置。java 线程“main”java.lang.RuntimeException中的异常:无法编译的源代码-错误的sym类型:示例。StdIn.is在示例中为空。verage.main(verage.java:16)Java结果:1 BUILD SU
问题内容: 本质上,我正在尝试替换: 为了避免使用硬盘驱动器,请在C ++中使用管道。这是我的代码: 我绝对可以确保上述字符串已正确初始化。但是,发生了两件事对我来说没有意义: (1)我正在执行的程序报告“输入文件为空”。由于我未使用“ <”调用程序,因此不应期望输入文件。相反,它应该期待键盘输入。此外,它应该阅读“ gulp_command”中包含的文本。 (2)程序的报告(通过标准输出提供)出
回顾一下我们写的第一个 Rust 程序就是带副作用的,其副作用就是向标准输出(stdout),通常是终端或屏幕,输出了 Hello, World! 让屏幕上这几个字符的地方点亮起来。println! 宏是最常见的输出,用宏来做输出的还有 print!,两者都是向标准输出(stdout)输出,两者的区别也一眼就能看出。至于格式化输出,基础运算符和字符串格式化小节有详细说明,这里就不再啰嗦了。 更通用
问题内容: 我知道Java中有一个函数可以使用method 将标准输出流设置为任何用户定义的值。 但是,是否有任何方法可以将标准输出重置为先前存储的标准输出还是标准输出? 问题答案: 您可以通过持有标准的文件描述符。要重置标准以打印到控制台,您可以 另一种方法是仅保留原始对象,如下所示:
问题内容: 我需要在Hudson中运行Shell脚本。该脚本需要用户回答。为了给出自动答案,我做了以下命令行: 这在Ubuntu终端中运行良好。但是,当我在Hudson作业中使用相同的命令时,脚本将自动执行所需的所有工作,但是最后,我得到了这两行错误: 这导致我的哈德森工作失败。 如何更改命令行以在Hudson中正常工作? 问题答案: 但是,您如何解释我在 本地 运行脚本时没有收到此错误,而从Hu
问题内容: 在Linux 3.0 / C ++下: 我想要一个执行以下操作的函数: 显然上述方法不起作用,但是您可以理解。我有一个字符串s,我希望将其作为应用程序“ foo”的子进程执行的标准输入传递,然后将其标准输出记录到字符串r中,然后将其返回。 我应该使用linux syscall或posix函数的什么组合? 问题答案: eerpini提供的代码无法正常工作。请注意,例如,之后将使用在父级中