如何将for循环的结果插入Postgres中的一个数组

时间:2018-10-10 06:41:09

标签: python postgresql for-loop

我有这个脚本

for row in c:
    res = subprocess.Popen('bgpq3 -4 {} -m 24 -l {}'.format(row[5],row[2]), shell=True, universal_newlines=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE)
    stdout, stderr = res.communicate()
    for line in stdout.split('\n')[1:10]:
          print(line)

结果:

ip prefix-list 2603 permit 2.16.6.0/23
ip prefix-list 2603 permit 2.16.8.0/24
ip prefix-list 2603 permit 2.16.9.0/24
ip prefix-list 2603 permit 2.16.10.0/24

如何将这些列表放入一个数组? 这样的事情或更好的方法会更容易!

{ip prefix-list 2603 permit 2.16.10.0/24,ip prefix-list 2603 permit 2.16.8.0/24,ip prefix-list 2603 permit 2.16.9.0/24,ip prefix-list 2603 permit 2.16.10.0/24}

还有我下次如何查询它们?就像获取多行的相反方法!

我使用了它,但是得到了多个带有多个数组的行

cursor.execute("INSERT INTO newpeers (prefix) VALUES(ARRAY['{}'])ON CONFLICT DO NOTHING".format(line))

我也尝试将结果附加到列表中,但是我得到的列表不止一个

lines = []
for line in stdout.split('\n')[1:10]:

0 个答案:

没有答案