python read_csv参数_Python panda read_csv在导入问题期间使用数据中的“-”值转换数据 - python...

我一直在努力解决这个问题。我终于找到了发生这种情况的原因,但还找不到解决方案。

我正在导入从网络上其他资源中抓取的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块是最佳选择。

在返回'Response'(Python)中传递多个参数 - python

我在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…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值