在行迭代中迭代列数据

时间:2018-08-30 13:51:31

标签: python csv python-3.7

我正在制作一个随机数循环,但也想循环另一个文件中已有的数据列。

简化示例:

out = /location/of/test.txt
file = open(out,'w')

var = [7,12,1,35,4]

for num in range(5):
    a = randint(1,10)
    file.write('%i ' % a)

    b = randint(1,10)
    file.write('%i ' % b)

file.write('\n')

我想要的结果是:

4   10  7
10  8   12
7   2   1
6   5   35
9   8   4

我的问题是,如何将var数组循环到代码中?

我尝试过类似的事情:

for num in range(5):
    a = randint(1,10)
    file.write('%i ' % a)

    b = randint(1,10)
    file.write('%i ' % b)

    for c in var:
       file.write('%i ' % c)

file.write('\n') 

但是结果将是:

4   10  7 12 1 35 4
10  8   7 12 1 35 4
7   2   7 12 1 35 4
6   5   7 12 1 35 4
9   8   7 12 1 35 4

我知道为什么会这样,我只是不知道如何遍历我的var以及生成的数字循环来创建所需的格式。

3 个答案:

答案 0 :(得分:1)

您不会在任何地方使用num,因此只需直接遍历var。我还建议您在with中使用open子句,并使用f字符串,该字符串在Python 3.6+中可用:

out = 'test.txt'
var = [12,12,12,12,12]
a, b = 10, 11

with open(out, 'w') as fin:
    for val in var:
        fin.write(f'{a} {b} {val}\n')

输出:

10 11 12
10 11 12
10 11 12
10 11 12
10 11 12

答案 1 :(得分:0)

除非我对您有误解,这应该是它的书写方式。 var数组中有5个变量。遍历数组并执行数组下面的其余逻辑。

out = /location/of/test.txt
file = open(out,'w')

var = [7,12,1,35,4]

for c in var:
    a = randint(1,10)
    file.write('%i ' % a)

    b = randint(1,10)
    file.write('%i ' % b)

    file.write('%i ' % c)

    file.write('\n') 

答案 2 :(得分:0)

findById