- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
as3:~/ngokevin-site# nano content/blog/20140114_test-chinese.mkd
as3:~/ngokevin-site# wok
Traceback (most recent call last):
File "/usr/local/bin/wok", line 4, in
Engine()
File "/usr/local/lib/python2.7/site-packages/wok/engine.py", line 104, in init
self.load_pages()
File "/usr/local/lib/python2.7/site-packages/wok/engine.py", line 238, in load_pages
p = Page.from_file(os.path.join(root, f), self.options, self, renderer)
File "/usr/local/lib/python2.7/site-packages/wok/page.py", line 111, in from_file
page.meta['content'] = page.renderer.render(page.original)
File "/usr/local/lib/python2.7/site-packages/wok/renderers.py", line 46, in render
return markdown(plain, Markdown.plugins)
File "/usr/local/lib/python2.7/site-packages/markdown/init.py", line 419, in markdown
return md.convert(text)
File "/usr/local/lib/python2.7/site-packages/markdown/init.py", line 281, in convert
source = unicode(source)
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe8 in position 1: ordinal not in range(128). -- Note: Markdown only accepts unicode input!
最佳答案
tl;博士/快速修复
reload
黑客 UnicodeDecodeError: 'ascii' codec can't decode byte
通常在您尝试转换 Python 2.x 时发生
str
包含非 ASCII 到 Unicode 字符串而不指定原始字符串的编码。
unicode()
(抛出异常的地方)作为其余代码的质量门 - 它将转换 ASCII 或将现有的 Unicode 字符串重新包装为新的 Unicode 字符串。 Markdown 作者无法知道传入字符串的编码,因此在传递给 Markdown 之前将依赖您将字符串解码为 Unicode 字符串。
u
在你的代码中声明。字符串的前缀。例如。
>>> my_u = u'my ünicôdé strįng'
>>> type(my_u)
<type 'unicode'>
str
即使您没有明确调用
unicode()
,也可能会发生 Unicode 转换.
UnicodeDecodeError
异常(exception):
# Explicit conversion without encoding
unicode('€')
# New style format string into Unicode string
# Python will try to convert value string to Unicode first
u"The currency is: {}".format('€')
# Old style format string into Unicode string
# Python will try to convert value string to Unicode first
u'The currency is: %s' % '€'
# Append string to Unicode
# Python will try to convert string to Unicode first
u'The currency is: ' + '€'
café
已根据终端类型以“UTF-8”或“Cp1252”编码进行编码。在这两个示例中,
caf
只是普通的ascii。在 UTF-8 中,
é
使用两个字节进行编码。在“Cp1252”中,é 是 0xE9(这也恰好是 Unicode 点值(这不是巧合))。正确
decode()
调用并成功转换为 Python Unicode:
decode()
用
ascii
调用(这与在没有给出编码的情况下调用
unicode()
相同)。由于 ASCII 不能包含大于
0x7F
的字节,这将抛出
UnicodeDecodeError
异常(exception):
str
正在出去的路上。这使您无需担心代码中间的字符串编码。
u
来创建 Unicode 字符串。 .例如。
u'Zürich'
# encoding: utf-8
io
模块提供了一个 TextWrapper,可以使用给定的
encoding
动态解码您的文件。 .您必须为文件使用正确的编码 - 它不容易被猜到。例如,对于 UTF-8 文件:
import io
with io.open("my_utf8_file.txt", "r", encoding="utf-8") as my_file:
my_unicode_string = my_file.read()
my_unicode_string
然后将适合传递给 Markdown。如果
UnicodeDecodeError
来自
read()
行,那么您可能使用了错误的编码值。
from backports import csv
import io
with io.open("my_utf8_file.txt", "r", encoding="utf-8") as my_file:
for row in csv.reader(my_file):
yield row
charset='utf8',
use_unicode=True
>>> db = MySQLdb.connect(host="localhost", user='root', passwd='passwd', db='sandbox', use_unicode=True, charset="utf8")
psycopg2.extensions.register_type(psycopg2.extensions.UNICODE)
psycopg2.extensions.register_type(psycopg2.extensions.UNICODEARRAY)
Content-type
header 应包含
charset
字段以提示编码。然后可以根据该值手动解码内容。或者,
Python-Requests返回
response.text
中的 Unicodes .
my_string.decode(encoding)
,其中
encoding
是适当的编码。此处给出了 Python 2.x 支持的编解码器:
Standard Encodings .同样,如果您收到
UnicodeDecodeError
那么你可能有错误的编码。
print
通过标准输出流写入。 Python 尝试在 stdout 上配置编码器,以便将 Unicode 编码为控制台的编码。例如,如果 Linux shell 的
locale
是
en_GB.UTF-8
,输出将被编码为
UTF-8
.在 Windows 上,您将被限制为 8 位代码页。
PYTHONIOENCODING
环境变量可以强制对 stdout 进行编码。
io.open
可用于透明地将 Unicode 转换为编码的字节字符串。
str
现在是 Unicode 字符串和旧的
str
现在是
bytes
.
.decode()
一个没有给出编码的字节字符串,Python 3 使用 UTF-8 编码。这可能解决了人们 50% 的 Unicode 问题。
open()
默认以文本模式运行,因此返回解码后的
str
(Unicode 的)。编码源自您的语言环境,在 Un*x 系统上通常是 UTF-8,或者在 Windows 机器上是 8 位代码页,例如 windows-1251。
sys.setdefaultencoding('utf8')
reload
是有原因的),它只会掩盖问题并阻碍您迁移到 Python 3.x。了解问题,解决根本原因并享受 Unicode zen。
关于python - 如何修复 : "UnicodeDecodeError: ' ascii' codec can't decode byte",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21129020/
双引号的 ASCII 数字是多少? (") 另外,是否有指向任何地方的列表的链接? 最后,如何进入C族(尤其是C#) 最佳答案 引号的 ASCII 码是 34。 (好吧,严格来说,它不是真正的引号,而
考虑一台计算机,它有一个字节可寻址内存,根据大端方案组织成 32 位字。程序读取在键盘上输入的 ASCII 字符并将它们存储在连续的字节位置,从位置 1000 开始。在输入名称“johnson”后显示
\x20 下的大多数 ASCII 代码似乎完全过时了。他们今天有没有使用?它们是否可以被视为“可供抢夺”,还是最好避免它们? 我需要一个分隔符来将“行”分组在一起,为此目的选择其中一个肯定会很好。 来
非字母数字或标点符号的字符称为不可打印: Codes 20hex to 7Ehex, known as the printable characters 那么为什么是例如005 可表示(并由 club
在我的一次面试中,面试官问我为什么在 ASCII 表中大写字母在小写字母之前,我在 google.com 上搜索但没有找到,谁能给我答案?多谢! 最佳答案 我只是猜测,但我想这是因为最早的字符集根本没
由于编码原因可能会让您感到恐惧(我不好意思说),我需要在单个字符串中存储多个文本项。 我将使用一个字符来分隔它们。 哪个字符最适合用于此目的,即哪个字符最不可能出现在文本中?必须是可打印的,并且可能小
我的代码将一大堆文本数据传递给负责存储这些数据的遗留库。但是,它倾向于删除尾随空格。当我读回数据时,这是一个问题。由于我无法更改遗留代码,因此我考虑用一些不常见的 ASCII 字符替换所有空格。当我读
我正在检查井号 (£) 的 ASCII 值。我找到了多个答案: http://www.ascii-code.com/说 A3 = 163 是井号的 ASCII 值。 http://www.asciit
我们好像只用了'\0'(null),'\a'(bell),'\b'(backspace),'\t'(水平制表符),'\n'(line fee) ,'\r'(回车),'\v'(垂直制表符),'\e'(转
当我查看 rust ASCII operations感觉之间存在一致性问题 is_lowercase/is_uppercase: pub fn is_uppercase(&self) -> bool
我一直假设 ASCII 码的范围是 0 到 255。昨晚我不得不处理一个我认为是下划线但结果是 Chr(8230) 的字符。三个类似下划线的小点。这是在 AutoHotKey 脚本中。问题已解决,但给
也许我在使用 Google 方面做得很糟糕,但这些规范适用于 Bencoding继续引用称为“十进制 ASCII”的东西,这让我认为它与常规 ASCII 不同。有人能解释一下吗? 最佳答案 base明
我正在尝试将小字符串转换为它们各自的 ascii 十进制值。就像将字符串“Ag”转换为“065103”一样。 我尝试使用 integer_variable : Integer := Integer'V
我想使用程序或图形库将图像转换为 ASCII 艺术,但我想指定要使用的调色板(符号)。所以基本上我想要一个图像,它从某个字母 A 呈现为文本,它是完整 ASCII 表的子集,例如 A := {a,b,
是否可以使用 Graphviz 绘制 ASCII 图表? 类似的事情: digraph { this -> is this -> a a -> test } 给出了不想要的结果。 相反,我
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
如何将 Žvaigždės aukštybėj užges 或 äüöÖÜÄ 之类的字符串转换为 Zvaigzdes aukstybej uzges 或 auoOUA,分别使用 Bash? 基本上我只
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How would you convert from ASCII to Hex by character i
我有一个成员搜索功能,您可以在其中提供部分姓名,返回的内容应该是至少具有与该输入匹配的用户名、名字或姓氏之一的所有成员。这里的问题是某些名称具有“奇怪”的字符,例如 Renée 中的 é 并且用户不想
我有文件名“abc张.xlsx”,其中包含某种非 ASCII 字符编码,我想删除所有非 ASCII 字符以将其重命名为“abc.xlsx”。 这是我尝试过的: import os import str
我是一名优秀的程序员,十分优秀!