所以我有一个这样的列表:
kesto = ['3m 24s', '45s', '1h 2m 40s']
我需要找到这些的平均值,最小值和最大值。 我试过了:
max_value = max(kesto)
min_value = min(kesto)
avg_value = sum(kesto)/len(kesto)
但当然它不起作用,因为这些不是数字。他们背后有“m”和“s”。
编辑:此代码工作正常,但它只返回它获得的第一个值。 例如,如果有“h”和“m”,它只返回“h” 所以1小时20分钟和1小时15分钟都是“3600”。
def parse_time(s):
s = s.split()
total = 0
for cl in s:
if cl[-1] == 'd':
total += int(cl[:-1]) * 60 * 60 * 24
if cl[-1] == 'h':
total += int(cl[:-1]) * 60 * 60
if cl[-1] == 'm':
total += int(cl[:-1]) * 60
if cl[-1] == 's':
total += int(cl[:-1])
return total
kesto2 = [parse_time(s) for s in kesto]
答案 0 :(得分:0)
创建一个将这些字符串转换为数字的函数,然后使用此函数:
def conv(x):
(m, s) = x.replace('m', '').replace('s', '').split()
return 60 * int(m) + int(s)
max_value = max(kesto, key=conv)
min_value = min(kesto, key=conv)
avg_value = sum(map(conv, kesto))/len(kesto)
答案 1 :(得分:0)
我建议你制作一个能够在几秒钟内转换你的价值的功能 例如“3m 24s”是204秒 我帮助你使用函数的签名:
def converter(value):
完成功能后,使用
max_value = max(kesto, key=converter)
min_value = min(kesto, key=converter)
依旧......
答案 2 :(得分:0)
s=0
n = []
for l in li:
s = (60*int(l[0]))+int(l[3:4])
n.append(s)
n
是您想要的清单。
答案 3 :(得分:0)
您可以使用strptime
解析这些条目,然后转换为timedelta
个对象。这些可以添加并除以整数:
from datetime import datetime, timedelta
NULL_TIMEDELTA = timedelta()
kesto = ['3m 24s', '45s', '1h 2m 40s']
def to_timedelta(strg):
if 'h' in strg:
tme = datetime.strptime(strg, '%Hh %Mm %Ss').time()
elif 'm' in strg:
tme = datetime.strptime(strg, '%Mm %Ss').time()
else:
tme = datetime.strptime(strg, '%Ss').time()
dte = datetime.combine(datetime.min, tme) # need a datetime object
td = dte - datetime.min # to create timedelta object
return td
timedeltas = [to_timedelta(item) for item in kesto]
max_value = max(timedeltas)
min_value = min(timedeltas)
avg_value = sum(timedeltas, NULL_TIMEDELTA)/len(timedeltas)
print(max_value) # 1:02:40
print(min_value) # 0:00:45
print(avg_value) # 0:22:16.333333
请注意,您必须使用sum
初始化NULL_TIMEDELTA = timedelta()
。默认值为0
- 但未定义int + timedelta
。
答案 4 :(得分:0)
下面的代码将时间转换为秒,并将它们添加到名为kestoS
的新列表中,因为它们都是相同的单位,现在您可以轻松地对它们进行排序。
首先使用split()
分隔分钟,当看到'm'时,分隔列表。我只取第一个值[0]
。通过将空格之后出现的字符取为's'来获得秒数。最后,我总计秒数并将它们添加到kestoS
。
此解决方案不受秒数或分钟数的位数限制。
kestoS =[]
for time in kesto:
minutes = time.split('m')[0]
seconds = time.[time.find(' ') + 1: time.find('s')]
kestoS.append((minutes*60)+seconds)
max_value = max(kestoS)
min_value = min(kestoS)
avg_value = sum(kestoS)/len(kestoS)
答案 5 :(得分:0)
希望这会有所帮助
import re
kesto = ['3m 24s', '1m 5s', '2m 40s']
kseto_total = []
for k in kesto:
# here split the two values and remove the m and s from string
minuite,second =k.replace('m','').replace('s','').split(' ')
# convert the string into int value
minuite=int(minuite)
second = int(second)
# calculating the total value and append into the new list
kseto_total.append(minuite*60+second)
# applying max, min and calculate average
max_value = max(kseto_total)
min_value = min(kseto_total)
avg_value = sum(kseto_total)//len(kseto_total)
print(kesto)
# printing the result into converting minute and secondd
print(max_value//60,'m',max_value%60,'s\n',
min_value//60,'m',min_value%60,'s\n',
avg_value//60,'m',avg_value%60,'s')
<强>更新强>
def format_string(time):
k1 = ''
k2 = ''
k3 = ''
if 'h' in time:
k1 = time
pass
else:
k1 = '0h ' + k
if 'm' in k1:
k2 = k1
pass
else:
k2 = '0m ' + k1
if 's' in k2:
k3 = k2
pass
else:
k3 = ' 0s' + k2
return k3
在这里,您可以调用字符串格式化函数。然后你可以作为评论描述不透明。字符串格式化可以有效的方式完成。这是唯一一个简单的解决方案。
答案 6 :(得分:0)
这是我将字符串转换为可用秒值的第一部分的解决方案,认为它运行良好
a=[[0, 0],[0, 0],[0, 0],[0, 0],[0, 0],[0, 0],[0, 0],[0, 0],[0, 0],[0, 0],[0, 1],[1, 1],[1, 1],[1, 5],[5, 12],[12, 6]]
b=[[0, 0],[0, 0],[0, 0],[0, 0],[0, 1],[1, 1],[1, 1],[1, 1],[1, 1],[1, 1],[1, 1],[1, 1],[1, 1],[1, 1],[1, 1],[1, 5],[5, 12],[12, 6]]
res = []
for _a in a:
if _a not in res:
occurence_count_a = a.count(_a)
occurence_count_b = b.count(_a)
res.extend ([_a for _ in range(min(occurence_count_a, occurence_count_b))])
print (res)
>>> [[0, 0], [0, 0], [0, 0], [0, 0], [0, 1], [1, 1], [1, 1], [1, 5], [5, 12], [12, 6]]
结果为kesto2 = [204,45,3760],以秒为单位。从那里你可以很容易地找到你的统计数据。