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…