- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有这个 Python3 代码来尝试从 utf-8 编码的文件中读取和打印:
f = open('mybook.txt', encoding='utf-8')
for line in f:
print(line)
当我使用 Sublime Text 3 构建时,出现以下错误:
UnicodeEncodeError: 'ascii' codec can't encode character '\u2019' in position 18: ordinal not in range(128)
但是,当我使用 python3 在终端中执行我的代码时,它可以正常工作。
我的构建配置是
{
"cmd": ["/usr/local/bin/python3", "$file"]
, "selector": "source.python"
, "file_regex": "file \"(...*?)\", line ([0-9]+)"
}
如果我把它改成:
f = open('mybook.txt', encoding='utf-8')
for line in f:
print(line.encode('utf-8'))
然后它确实打印出 utf-8 编码的字节字符串(我认为这就是正在发生的事情)。
b'Hello\n'
b'\xc2\xab\xe2\x80\xa2\n'
b'Goodbye'
但我也不知道如何从这里转到在屏幕上打印 unicode 字符...
此外,如果我尝试根据 A python program fails to execute in sublime text 3, but success in bash 更改此环境变量它仍然没有解决它。
最佳答案
答案实际上在您问题中链接的问题中 - PYTHONIOENCODING
需要设置为"utf-8"
.但是,由于 OS X 很愚蠢,不会接受在终端中或通过 .bashrc
设置的环境变量。或类似文件,这将无法按照其他问题的答案中指示的方式工作。相反,您需要将该环境变量传递给 Sublime。
幸运的是,ST3 构建系统(我不知道 ST2)有 "env"
选项。这是传递给 exec.py
的键和值的字典,它负责在没有 "target"
的情况下运行构建系统选项集。正如我们在上面的评论中所讨论的,我指出当在 Linux 上使用 ST3(Build 3122)运行时,您的示例程序在包含非 ASCII 字符的 UTF-8 编码文本文件上运行良好,但在 OS X 上运行的相同版本则不然. 让它运行所需要做的就是更改构建系统以包含以下行:
"env": {"PYTHONIOENCODING": "utf8"},
我保存了构建系统,点击 ⌘B,程序运行正常。
顺便说一句,如果你想阅读 exec.py
, 或 Packages/Python/Python.sublime-build
,或打包在 .sublime-package
中的任何其他文件归档,安装 PackageResourceViewer
通过包控制。使用命令面板中的“打开资源”选项选择单个文件或“提取包”(两者都以“PackageResourceViewer:”开头,或 prv
使用模糊搜索)将整个包提取到您的 Packages
文件夹,通过选择 Sublime Text → Preferences → Browse Packages…
访问(只是 Preferences → Browse Packages…
在其他操作系统上)。它位于您硬盘上的以下位置:
~/.config/sublime-text-3/Packages
~/Library/Application Support/Sublime Text 3/Packages
C:\Users\<b><i>YourUserName</i></b>\AppData\Roaming\Sublime Text 3\Packages
<b><i>InstallationFolder</i></b>\Sublime Text 3\Data\Packages
一旦文件保存到您的 Packages
文件夹(如果您只是通过“打开资源”选项查看它们并在不更改或保存它们的情况下关闭它们,它们将不会),它们将覆盖 .sublime-package
中包含的同名文件。文件。因此,例如,如果您想编辑默认值 Python.sublime-build
文件在 Python
包,您的更改将保存为 Packages/Python/Python.sublime-build
, 当您选择 Python
从菜单构建系统,它只会使用你的版本。
关于python - 使用 Sublime Text 3 在 Python 3 中打印 UTF-8,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39576308/
我目前正在创建一个正则表达式来拆分所有匹配以下格式的字符串:&[text(text - text text) !text]。这里的文本实际上可以是任何字符。并且间距很重要。文本将如图所示列出。 我已经
这个问题在这里已经有了答案: Remove duplicate commas and extra commas at start/end with RegExp in Javascript, and
我有以下代码。 from xml.dom.minidom import Document doc = Document() root = doc.createElement('root') doc.a
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Find text string in jQuery and make it bold 如何使用 jQuer
我使用 libmagic 在我的元素的 Web 界面中获取文件的 MIME 类型。我在 css 和 js 文件上得到文本/纯 mime 类型。 例如 chromium 显示以下警告: Resource
起初我必须阅读很多教程,但我仍然不知道我做错了什么...... 我想内联使用 4 个 div。在我想放置的那些 div 中:文本、图像、文本、文本。我希望中间文本自动设置为最大宽度。 我写了一个简单的
我想替换所有出现的 [b: "text"]至text使用 JavaScript 和 RegEx。目前我知道如何替换 [b: ""]至使用'/\[b: ""\]/g'但我不知道如果 " 之间有文本该怎么
这可能是一个幼稚的问题,但我想知道是否有比使用 text() 更好的方法将文本添加到绘图中。注意,我也在使用 layout()以及。具体来说,我有一个情节的一部分,我想在其中添加一些带有标题的文本,然
我必须反复从 latex 源粘贴代码,因此每次都必须做很多查找和替换操作('“a'=>'ä','” o'=>'ö',...) 。 有没有一种方法可以存储这些搜索和替换规则,例如,我可以通过一次按键执行
当我在Sublime Text 3代码屏幕中编写代码时,它连续地向右滑动,如图所示。我该怎么办? 请注意第10行。 最佳答案 如果您只想为当前 View (正在编辑的当前文件)激活自动换行,只需vie
是否有可能更改 sublime text 中的默认字体目录?我只想使用可移植 sublime 文本存储在我的 pendrive 上的字体,这样我就不必在我使用可移植 sublime 文本的每台机器上安
我是 Android 开发的新手,我有一个愚蠢的问题。如何将“文本字段”框放在一行中的文本旁边。 例子: Please Enter the number: [ ] 关于 "t
我想自动将“我的文本”更改为“我的文本”,因为这是用德语写的正确方式。引号可以在文本中的任何位置。 有没有一种简单的方法可以实现这一点? 解决方案应该检查第一个字符,最后一个字符,比如“this”,或
我想知道是否有特殊的语法来绑定(bind)与现有文本连接的文本。 像这样。 显然,这行不通。 什么是最佳实践? 使用 SL4。 最佳答案 使用StringFormat在 Binding 上。 WPF
我认为它应该打印“真实文本”,因为它相当于 true console.log('true text' || true ? 'text' : 'text1'); 但是,输出是“文本”;抱歉,如果是愚蠢的
有没有办法通过 css 打破文本,以便中间有一个“空白”?目前我正在通过手工打破文本来解决这个问题 -但这是愚蠢的。我知道有一个函数可以让文本在另一个 div 中结束和开始,但 IE 不支持它。 文本
我想为我的Tcl/Tk工具实现一个效果:在text控件中,根据具体情况,希望高亮一些线条的背景色,其他线条正常透明.有可能吗? 我尝试了一些选项,例如:-highlightbackground 、-i
我正在尝试解析原始维基百科文章内容,例如the article on Sweden ,使用re.sub()。但是,我在尝试替换 {{some text}} block 时遇到了问题,因为它们可以包含更
我试图先删除 ComboBox 中的所有内容。然后在其前面添加文本,但保留了一些旧文本。有没有办法重置或清除 ComboBox?或者我怎样才能最好地实现这一目标? public void GetBad
我知道我们应该创建 Example对象并将其传递给 nlp.update() 方法。根据 docs 中的示例, 我们有 for raw_text, entity_offsets in train_da
我是一名优秀的程序员,十分优秀!