首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么我得到"can't multiply sequence by non-int of type 'float'“错误?

为什么我得到"can't multiply sequence by non-int of type 'float'“错误?
EN

Stack Overflow用户
提问于 2020-10-19 09:53:33
回答 1查看 69关注 0票数 0

级别:初学者

为什么我得到"can't multiply sequence by non-int of type 'float'“错误?

代码语言:javascript
复制
import openpyxl as xl
wb = xl.load_workbook('transaction.xlsx')
sheet = wb['Sheet1']


for row in range(2, sheet.max_row + 1):
    cell = sheet.cell(row, 3)
    new_price = cell.value * 0.9
    new_price_cell = sheet.cell(row, 4)
    new_price_cell.value = new_price

wb.save('transaction1.xlsx')

我正在导入transaction.xlsx文件。

sample input of transaction file

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-19 10:23:29

这是因为price列中的值包含$符号,这意味着该列中的所有值都是strings。为了将它们转换成floats,只需使用.replace方法删除$符号,并将它们type castfloats中。这就是你怎么做的:

代码语言:javascript
复制
for row in range(2, sheet.max_row + 1):
    cell = sheet.cell(row, 3)
    new_price = cell.value
    new_price = float(new_price.replace("$","")) * 0.9
    new_price_cell = sheet.cell(row, 4)
    new_price_cell.value = new_price
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64420150

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档