我有一个Python脚本,它以urls
列表作为输入,通过for循环运行。我想能够交错/随机排列urls
的序列,并在1小时内运行它们。你知道吗
是否可以读取文件,以秒为单位为每一行分配一个值,然后启动一个计数器,一旦计数器到达时隙,它就会触发文件中特定行的脚本?你知道吗
更新:
基于下面的帮助,我创建了这个脚本来测试num.txt文件有一个字母列表,我测试了60秒而不是1小时的脚本。你知道吗
f = open('num.txt')
url = f.readlines()
x=random.sample(xrange(60), 60)
i=0
for u in url:
time.sleep(x[i])
print time.strftime("%H:%M:%S"), u
i+=1
time.sleep(x[i])
输出为18:25:19 a 18:26:00 b 18:26:35 c 18:27:01 d 18:27:43 e 18:27:56 f
我想做的是给每个字母随机分配一个时隙,例如a = 44 b = 57 c = 12 d = 30 e = 22 f = 48
因此,当脚本启动时,计数器开始计时(以秒为单位),一旦满足分配给每个字母的时间,它们就会在循环中运行,例如c
将在12秒时在循环中运行,e
将在22秒时运行,等等,这有意义吗?你知道吗
从你的comment:
编辑#1:
我想你的意思是这样的,用^{} :
说明:
所以基本上,
random.sample()
创建了一个随机排序的列表,所有的数字都在0-3600之间。然后,在for循环中,time.sleep()
为每次迭代获取列表的唯一值。所以对于第一次迭代,使用列表的第一个元素,对于第二次迭代,使用第二个元素等等然后,在for循环执行之后,可以使用
sum()
和切片表示法x[i:]
来添加列表的其余值,然后使用time.sleep()
来休眠剩余的时间。你知道吗编辑#2:
对于更新的示例,请尝试以下操作:
如果你的num.txt文件文件如下:
此代码将输出:
我不确定我是否理解这个问题, 为什么不先用以下命令将文件加载到列表中:
相关问题 更多 >
编程相关推荐