我是python的新手,我使用pandas从网站上抓取了一个表,并将其保存为csv文件,然后每隔60秒循环运行一次代码。每次循环运行时,我希望文件名不同或编号不同。我试过下面的方法
import pandas as pd
import time
starttime = time.time()
i=1
while True:
url = 'https://www.moneycontrol.com/india/indexfutures/nifty/9/2021-05-27/OPTIDX/CE/12800.00/true
optionchain = pd.read_html(url,attrs = {'class' : 'tblopt'})
chaindata = pd.DataFrame(optionchain[1])
chaindata1 = chaindata.rename(columns={0:'LTPcall',1:'Net Change',2:'Volume',3:'Open
Interest',4:'Change In Open Int',5:'StrikePrice',6:'LTPput',7:'Net Change',8:'Volume',9:'Open
Interest',10:'Change In Open Int'})
s = 'file'
x = (s+str(i))
chaindata1.to_csv(r'C:\Users\dell\Desktop\data\%x.csv')
i=+1
time.sleep(60.0 - ((time.time() - starttime) % 60.0))通过运行这个命令,我得到的第一个文件是file1,然后是file(x),它会一直覆盖file(x)。我想让它以file1、file2、file3等格式流动
发布于 2021-05-02 01:40:08
i=+1什么也不做,它只是将+1赋值给i。Alson,您可以使用str.format格式化文件名。例如:
import pandas as pd
import time
starttime = time.time()
i = 1
while True:
url = "https://www.moneycontrol.com/india/indexfutures/nifty/9/2021-05-27/OPTIDX/CE/12800.00/true"
optionchain = pd.read_html(url, attrs={"class": "tblopt"})
chaindata = pd.DataFrame(optionchain[1])
chaindata1 = chaindata.rename(
columns={
0: "LTPcall",
1: "Net Change",
2: "Volume",
3: "Open Interest",
4: "Change In Open Int",
5: "StrikePrice",
6: "LTPput",
7: "Net Change",
8: "Volume",
9: "Open Interest",
10: "Change In Open Int",
}
)
chaindata1.to_csv(
r"C:\Users\dell\Desktop\data\file{}.csv".format(i)
) # <-- use str.format here
i += 1 # <-- use i += 1 instead of i = +1
time.sleep(60.0 - ((time.time() - starttime) % 60.0))https://stackoverflow.com/questions/67348899
复制相似问题