我在Python2.7.10上编写了一个函数,它读取一个.txt文件,并从该文件的行中列出一个列表,然后按以下参数排序:
到目前为止我的代码是:
import operator #imported before function
INDEXArrivalHour = 4 #imported before function
inFile = open("services0604.txt", "r")
inFile = inFile.readlines()[7:]
servicesList = []
for line in inFile:
servicesList.append(line.rstrip().split(", "))
servicesList = sorted(servicesList, key = operator.itemgetter(INDEXArrivalHour))
return servicesList
打印函数的结果:
[
['Maria Conceicao'<-#driver name, '13-GH-88', 'John Tush', '11:30', '11:50'<-#hour her service ends, 'alfama', '30', 'charges'],
['Josefino Branco', '07-BB-99', 'Louis Amber', '11:05', '11:50', 'baixa', '45', 'terminates'],
['Dominique Bart', '04-TY-86', 'Sarah Lino', '11:10', '12:10', 'lumiar', '80', 'terminates'],
['Tiago Quaresma', '17-VI-90', 'Paulo Silva', '12:05', '12:30', 'alvalade', '30', 'terminates']
]
根据第二个参数,第一个列表应该在第二个列表之后。我试过使用两个分开的sorted(),但它不起作用,我玩过“key=”,但我真的卡住了,没有主意了。 如果有人能帮助我,我将不胜感激
两次单独排序将无法正常工作,因为第一次排序的结果将被丢弃
而是直接按两个属性排序:
这将为每个项使用一个元组
(x[4], x[0])
来确定排序x[4]
是时间,x[0]
是名称相关问题 更多 >
编程相关推荐