将数据从Python放入excel工作表中

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

我正在尝试将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])

python excel xlsxwriter
1个回答
0
投票

我认为问题出在下面的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]]都会出错。

希望这对您有帮助!

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