消息关闭
    暂无新消息!

python 如何将字符串转换成列表

问题作者 : MCGilligan2017-05-16发布

如何将字符串如a = "我是中国人",转换成列表li =["我","是","中","国","人"]

a = "我是一个中国人"
li = list(a)
print li

输出却是

['\xe6', '\x88', '\x91', '\xe6', '\x98', '\xaf', '\xe4', '\xb8', '\x80', '\xe4', '\xb8', '\xaa', '\xe4', '\xb8', '\xad', '\xe5', '\x9b', '\xbd', '\xe4', '\xba', '\xba']

我用JavaScript很简单的就实现了

var a = "我是中国人"
li = a.split("")
console.log(li) // >>>["我","是","中","国","人"]

不知道python应该如何实现?


7个回答

︿ 0
# -*- coding: utf-8 -*-
def unicode_chars(s):
    if not isinstance(s, unicode):
        s = s.decode("utf-8")
    return [c for c in s]

print unicode_chars("我是中国人")[0]
print unicode_chars(u"我是中国人")[1]
print unicode_chars(r"我是中国人")[2]
print unicode_chars(b"我是中国人")[3]
#>> 我
#>> 是
#>> 中
#>> 国
︿ 0

python3没有编码问题

In [20]: a
Out[20]: '我是中国人'

In [21]: li=list(a)

In [22]: li
Out[22]: ['我', '是', '中', '国', '人']
︿ 0

对于不内置Unicode字符支持的语言,可以考虑使用正则分割,因为正则库PCRE支持Unicode字符,比如PHP:

var_export(preg_split('##u', '中国人民银行', null, PREG_SPLIT_NO_EMPTY));
// array(0=>'中',1=>'国',2=>'人',3=>'民',4=>'银',5=>'行')

Python 2应该也支持类似写法.

︿ 0

可以先将字符串解编码成unicode, 再用list

# 第一种:
>>> a = u"我是中国人"
>>> s = list(a)
>>> print s
[u'\u6211', u'\u662f', u'\u4e2d', u'\u56fd', u'\u4eba']
>>> print s[1]
是

# 第二种
>>> a = "我是中国人"
>>> s = a.decode('utf8')
>>> s = list(a.decode('utf8'))
>>> s
[u'\u6211', u'\u662f', u'\u4e2d', u'\u56fd', u'\u4eba']
>>> print s[1]
是
︿ 0

1、不用list(a),直接

for each in a:   
    print each
      

这样就可以,和编码没关系,和python2或python3也没关系

2、可以把a直接当作一个list了,取得话就用 a[num]切片就可以,比如取“我”就是a[0],取“中国”可以用a[2:3]