我正在尝试将kwargs函数的输出放入带有一栏股票代码,一栏具有当前价格的excel表中。该代码仅使用股票名称就可以正常工作,但是当我添加价格时,它使我返回了此错误:
MMMTraceback (most recent call last):
File "C:\Users\sss\Documents\Python Programs\Bot\Td\td4.py", line 52, in <module>
154.95
get_ohlc(symbol=[row])
File "C:\Users\sss\Documents\Python Programs\Bot\Td\td4.py", line 43, in get_ohlc
for symbol, lastPrice in zip(data[symbol],data[lastPrice]):
KeyError: 154.95
其中154.95是该特定股票的最新价格。我很困惑为什么它把价格作为错误给了我。相关代码如下,在此先感谢您的帮助!
import pandas as pd
data_sheet1 = pd.read_excel('C:\\Users\\sss\\Downloads\\companylist.xlsx', index_col=0)
data_impor = data_sheet1.head(10)
workbook = xlsxwriter.Workbook('c:\\Users\\sss\\Documents\\output.xlsx')
worksheet = workbook.add_worksheet()
worksheet.write('A1', 'Stock')
worksheet.write('B1', 'Price')
row_1 = 1
col = 0
def get_ohlc(**kwargs):
data = get_quotes(symbol=kwargs.get('symbol'))
for symbol in kwargs.get('symbol'):
print(symbol)
print(data[symbol]['lastPrice'])
lastPrice = data[symbol]['lastPrice']
for symbol, lastPrice in zip(data[symbol],data[lastPrice]):
global row_1
worksheet.write(row, col, symbol)
worksheet.write(row, col + 1, lastPrice)
row += 1
workbook.close()
for row in data_impor.index:
get_ohlc(symbol=[row])
我认为问题出在下面的for-loop
,
for symbol, lastPrice in zip(data[symbol],data[lastPrice]): #on this line data[lastprice]
global row_1
worksheet.write(row, col, symbol)
worksheet.write(row, col + 1, lastPrice)
row += 1
如果要从列表中访问元素,则不能将其传递给索引以外的其他值。如果您每次都使用data[lastPrice]
,并且如果lastprice
不是索引,则每次使用data[lastPrice]
]都会出错。
希望这对您有帮助!