我试图获得从expenses\u calc函数获得的返回值的总和,但我面对的是“TypeError:'float'object is not iterable”。要解决此错误,需要进行哪些更改?在
from nsetools import Nse
nse = Nse()
#Name of stocks and buy prices
stocks = {
"APLAPOLLO": 878.2,
"AVANTIFEED": 488.95,
"BALAMINES": 308.95
}
#Quantity of stocks
qty = {
"APLAPOLLO": 10,
"AVANTIFEED": 10,
"BALAMINES": 10
}
def get_closing(stock):
"""
Function to obtain closePrice of stocks
"""
return nse.get_quote(stock)['buyPrice1']
def expenses_calc(buy,sell,qty):
"""
Function to calculate the applicable expenses
"""
stt = 0.10
ttc = 0.00325
service_tax = 15.0
sebi_charges = 0.0002
swacch_bharat_cess = 0.02
stamp_duty = 0.01
turnover = (buy * qty) + (sell * qty)
stt_total = (stt / 100) * turnover
total_tran_charge = (ttc / 100) * turnover
service_tax = (service_tax / 100) * total_tran_charge
sebi_charges = (sebi_charges / 100) * turnover
stamp_duty = (stamp_duty / 100) * turnover
total_tax_and_charges = stt_total + total_tran_charge + service_tax + sebi_charges + stamp_duty
total_investment = buy * qty
current_value = sell * qty
net_profit = (sell * qty) - (buy * qty) - total_tax_and_charges
return net_profit
#For loop that calls the expenses_calc function in a loop with the right arguments
for key in stocks.keys():
buy_price = stocks[key]
sell_price = get_closing(key)
stock_qty = qty[key]
expenses_func_call = expenses_calc(buy_price, sell_price, stock_qty)
print(sum(expenses_func_call))
发生类型错误的行
^{pr2}$我尝试过创建一个空的myresults列表,然后将expenses\u calc函数的返回值附加到该列表中,然后打印列表的总和,这也不起作用。在
for key in stocks.keys():
myresults = []
buy_price = stocks[key]
sell_price = get_closing(key)
stock_qty = qty[key]
expenses_func_call = expenses_calc(buy_price, sell_price, stock_qty)
myresults.append(expenses_func_call)
print(sum(myresults))
除了前面的答案之外,您还需要向
sum
函数传递一个列表,这样您更正问题的初始尝试是正确的。但是您应该在进入循环之前初始化myresults
列表。目前,每次执行循环时,实际上是在重写myresults
内容。在在下一次尝试向列表myresults追加值时,print语句应该在for循环之外
相关问题 更多 >
编程相关推荐