首页 > 其他 > 详细

关于在2.7中出现 "UnicodeWarning: Unicode equal comparison failed to convert both arguments to Unicode - interpreting them as being unequal"

时间:2016-11-03 09:31:14      阅读:2231      评论:0      收藏:0      [点我收藏+]

在中文字符串前面加u. 

 

Make sure your code is in UTF-8 (NOT Latin-1) and/or use a coding line as so:

#! /usr/bin/python
# -*- coding: utf-8 -*-
a = {"a": u"??"}
b = "??"
assert b == a[a]
assert b.decode(utf-8) == a[a].decode(utf-8)

 

If you‘re using unicode across the board, you can import unicode_literals from the future and cut back on encoding heartaches:

#! /usr/bin/python
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
a = {"a": u"??"}
b = "??"
assert b == a[a]
assert b == a[a]
assert b.encode(utf-8) != a[a]
assert b.encode(utf-8) == a[a].encode(utf-8)

 

If a file uses unicode_literals, all "strings" are now u"unicode" objects (per the coding of the file) if they‘re not b"prepended" with a b (to emulate the string/bytes split in Python 3.X).

 

关于在2.7中出现 "UnicodeWarning: Unicode equal comparison failed to convert both arguments to Unicode - interpreting them as being unequal"

原文:http://www.cnblogs.com/qingyuanjushi/p/6025229.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!