Python元组数据成对,如何读取其中一个数据?
例如[('the',5),('of',4),('a',3),('people',2),('is',2),('when',2),('beating',2)]这样一个元组,我...
例如[('the', 5), ('of', 4), ('a', 3), ('people', 2), ('is', 2), ('when', 2), ('beating', 2) ]这样一个元组,我如何只读取每组数据中后面那个数字?我能否对该元组进行排序(排序方式是先根据后面数字大小,同等数字的看前面字母顺序按a-z排)?
如果不能的话,我能否把该元组转成一个列表,再依照上面的排序方式进行排序呢? 展开
如果不能的话,我能否把该元组转成一个列表,再依照上面的排序方式进行排序呢? 展开
展开全部
python tuple是重要的数据格式
下面用代码的形式给你列出用法
#不可变序列-----元组 tuple
#元组和列表十分相似,元组和字符串一样都是不可变的。
#元组由不同的元素组成,每个元素可以存储不同类型的数据,例如
#字符串、数字和元组
#元组通常代表一行数据,而元组中的元素则代表不同的数据项
#创建元组,不定长,但一旦创建后则不能修改长度
#空元组
tuple_name = ()
#如果创建的元组只有一个元素,那么该元素后面的逗号是不可忽略的
>>>(4)
4
>>>user = ('01','02','03','04')
#添加元组
user = (user,'05')
==>(('01','02','03','04'),'05')
#去重
>>> set((2,2,2,4,4))
set([2, 4])
#访问元组
user[0]
#不可修改元素
>>> user=(1,2,3)
>>> user[0]=2
Traceback (most recent call last):
File "<pyshell#5>", line 1, in <module>
user[0]=2
TypeError: 'tuple' object does not support item assignment
#访问二元元组
user1 = (1,2,3)
user2 = (4,5,6)
user = (user1,user2)
==>((1,2,3),(4,5,6))
print user[0][0]
#解包
user = (1,2,3)
a,b,c = user
a=1,b=2,c=3
#元组的遍历
#range([start],stop,[,step]) 返回一个递增后者递减的 数字 列表
for item in range(len(user)):
print user[item]
#二元元组的访问
for i in range(len(user)):
for j in range(len(user)):
print 'user['+str(i)+']['+str(j)+']=',user[i][j]
#使用map()实现遍历
#map(function_name,sequence[,sequence...])
#返回 function处理后的列表
#sequence 元组或列表
for item in map(None,user):
for i in item:
print i
展开全部
首先这是一个由元组组成的列表,可以直接排序
>>> s=[('the', 5), ('of', 4), ('a', 3), ('people', 2), ('is', 2), ('when', 2), ('beating', 2) ]
>>> s.sort(key=lambda x:(x[1],x[0]))
>>> s
[('beating', 2), ('is', 2), ('people', 2), ('when', 2), ('a', 3), ('of', 4), ('the', 5)]
>>> s=[('the', 5), ('of', 4), ('a', 3), ('people', 2), ('is', 2), ('when', 2), ('beating', 2) ]
>>> s.sort(key=lambda x:(x[1],x[0]))
>>> s
[('beating', 2), ('is', 2), ('people', 2), ('when', 2), ('a', 3), ('of', 4), ('the', 5)]
追问
太感谢了!
但是不好意思刚才没说清楚,数字也要按从大到小排,这个怎么办呢?
追答
你的意思是数字从大到小,字母按字典顺序
如果数字都是正数
>>> s=[('the', 5), ('of', 4), ('a', 3), ('people', 2), ('is', 2), ('when', 2), ('beating', 2) ]
>>> s.sort(key=lambda x:(-x[1],x[0]))
>>> s
[('the', 5), ('of', 4), ('a', 3), ('beating', 2), ('is', 2), ('people', 2), ('when', 2)]
统计单词个数应该不会有负数吧
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询