提高python脚本的速度

问题描述 投票:1回答:1

无论如何都有提高以下的速度。代码将修饰符插入到http请求中。修改器是5位数的电子邮件ID。目标是将每个结果添加到JSON文件中。

我知道摆脱Progessbar()将有所帮助,但我发现减速值得功能的实用性。 Try Except Else部分再次放慢速度再次退出,但是idents有4500个条目。有任何想法吗?

import urllib3
import json
import csv
from progressbar import ProgressBar
pbar = ProgressBar()

with open('blim2.csv', newline='') as csvfile:
    idents = csv.reader(csvfile, delimiter=' ', quotechar='|')
    json_arr = []
    while True:
        try:
             for x in pbar(idents):
                http = urllib3.PoolManager()
                r = http.request('GET', 'https://api.pipedrive.com/v1/mailbox/mailMessages/'+"".join(x)+'?include_body=1&api_token=token')
                mails = json.loads(r.data.decode('utf-8'))
                json_arr.append(mails)
                with open('test2.json', 'w') as outfile:
                    json.dump(json_arr, outfile)             
        except:
            continue
        else:
            break
python
1个回答
0
投票

尝试将while True循环一直移动到内部,以便仅重试单个请求。此外,最后只写一次文件。

import urllib3
import json
import csv
from progressbar import ProgressBar
import time

pbar = ProgressBar()
base_url = 'https://api.pipedrive.com/v1/mailbox/mailMessages/'
fields = {"include_body": "1", "api_token": "token"}

json_arr = []
http = urllib3.PoolManager()
with open('blim2.csv', newline='') as csvfile:
    for x in pbar(csv.reader(csvfile, delimiter=' ', quotechar='|')):
        while True:
            try:
                r = http.request('GET', base_url + "".join(x), fields=fields)
                break
            except Exception:
                # wait a bit before trying again
                time.sleep(1)  # seconds
        mails = json.loads(r.data.decode('utf-8'))
        json_arr.append(mails)
with open('test2.json', 'w') as outfile:
    json.dump(json_arr, outfile)

您还应该查看在您的案例和except中实际引发的异常。否则你可能会掩盖其他问题。我已经用except替换了你的裸except Exception,这至少允许用户按Ctrl + C中止程序。

© www.soinside.com 2019 - 2024. All rights reserved.