我一直在努力解决这个问题。我终于找到了发生这种情况的原因,但还找不到解决方案。
我正在导入从网络上其他资源中抓取的data.csv。它们的大部分是字符串,需要除去,例如“%”。使用自定义转换器时,它的工作原理就像一种魅力。
但是,只要一列包含带有“-”(无值)的行,它就会在convert_percentage中显示错误“ File“ D:test.py”,第14行
返回float(new_val)ValueError:无法将字符串转换为float:'-'“
我正在使用以下代码行:
import pandas as pd
import numpy as np
def convert_percentage(val):
new_val = val.replace(',','').replace('%', '')
return float(new_val)
df = pd.read_csv('data.csv', na_values=['-'],
converters={
'Perf Month': convert_percentage,
'Perf Week': convert_percentage,
'Perf Quarter': convert_percentage,
'Perf Half Y': convert_percentage,
'Payout': convert_percentage,
})
参考方案
我建议你这样做:
def convert_percentage(val):
new_val = val.replace(',','').replace('%', '')
try:
return float(new_val)
except ValueError:
return new_val
显然,您可以根据要返回的内容添加更多收益。如果您认为应该每次检查if,请有条件返回。但是,如果错误非常严重(从统计上来说),则try/except
块是最佳选择。
我在Angular工作,正在使用Http请求和响应。是否可以在“响应”中发送多个参数。角度文件:this.http.get("api/agent/applicationaware").subscribe((data:any)... python文件:def get(request): ... return Response(seriali…
Python exchangelib在子文件夹中读取邮件 - python我想从Outlook邮箱的子文件夹中读取邮件。Inbox ├──myfolder 我可以使用account.inbox.all()阅读收件箱,但我想阅读myfolder中的邮件我尝试了此页面folder部分中的内容,但无法正确完成https://pypi.python.org/pypi/exchangelib/ 参考方案 您需要首先掌握Folder的myfo…
R'relaimpo'软件包的Python端口 - python我需要计算Lindeman-Merenda-Gold(LMG)分数,以进行回归分析。我发现R语言的relaimpo包下有该文件。不幸的是,我对R没有任何经验。我检查了互联网,但找不到。这个程序包有python端口吗?如果不存在,是否可以通过python使用该包? python参考方案 最近,我遇到了pingouin库。
如何用'-'解析字符串到节点js本地脚本? - python我正在使用本地节点js脚本来处理字符串。我陷入了将'-'字符串解析为本地节点js脚本的问题。render.js:#! /usr/bin/env -S node -r esm let argv = require('yargs') .usage('$0 [string]') .argv; console.log(argv…
TypeError:'str'对象不支持项目分配,带有json文件的python - python以下是我的代码import json with open('johns.json', 'r') as q: l = q.read() data = json.loads(l) data['john'] = '{}' data['john']['use…