![](/img/trans.png)
[英]How to save your data you've already loaded and processed in Google Colab notebook so you don't have to reload it everytime?
[英]How to break for loop while handling API error so you don't lose all your data
我有一个for循环,不断将参数传递给API。 我将从API调用中获取响应,并将其附加到3个列表中。 for循环完成后,我将创建一个熊猫数据框,然后将其写入.csv文件。
整个循环大约需要20分钟才能运行,而我在10分钟内就遇到了一个错误,因此我丢失了所有数据,然后才能将其写入数据框,然后再写入.csv文件。
您如何更好地处理这种情况?
# Create empty lists for data
email = []
is_disposable_address = []
mailbox_verification = []
for address in emails_to_validate:
parameters = {"address": address}
response = requests.get(url, params=parameters,
auth=("api", "key"))
email.append(address)
is_disposable_address.append(response.json()["is_disposable_address"])
mailbox_verification.append(response.json()["mailbox_verification"])
# Combine lists into dictionary and create dataframe
data = {"email_address": email,
"is_disposable_address": is_disposable_address,
"mailbox_verification": mailbox_verification}
dF = pd.DataFrame(data)
# Export to csv
dF.to_csv("emails.csv", index=False)
最简单的解决方案是将循环包装在try / catch块中,如下所示:
try:
for address in emails_to_validate:
parameters = {"address": address}
response = requests.get(url, params=parameters,
auth=("api", "key"))
email.append(address)
is_disposable_address.append(response.json()["is_disposable_address"])
mailbox_verification.append(response.json()["mailbox_verification"])
except Exception as e:
print('An exception has occurred. Giving up on loop:')
print(e)
然后执行将继续执行代码的后续部分。
如果要继续处理后续列表项,也可以将Try
/ Except
块放入循环中。
有关如何使用try / except以及对错误类型进行更多细微差别的条件的更多详细信息,请参阅有关异常处理的文档。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.