如何从Python中删除包含字符串的字符?

2024-09-27 22:34:36 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在使用一大组csv(表),我需要删除包含字符的单元格,并保留数字单元格。你知道吗

例如。你知道吗

   p1     p2      p3       p4      p5
 dcf23e   2322   acc41   4212     cdefd

所以在本例中,我只想删除dcf23e、acc41和cdefd。删除这些字符串后,我想将它们保留为空单元格。你知道吗

我该怎么做?提前谢谢。你知道吗

我试过的代码是。。。,这段代码删除了字符串中的字符,但问题是,如果字符串是23cdgf2,它将生成一个不是我想要的字符串232。删除所有字符后,当我尝试将字符串转换为int进行计算时,有些字符串变成了小数,因为有些字符串有123def.24->;123.24

temp = ''.join([c for c in temp if c in '1234567890.']) # Strip all non-numeric characters
# Now converting strings to integers for calculations, Using function to use   int() , because of the blank spaces cannot be converted to int
def mk_int(s):
    s = s.strip()
    return int(s) if s else 0
mk_int(temp)
print(temp)

Tags: csvto字符串代码inforif数字
3条回答

我会用一个简单的设置做快速测试。你知道吗

a = 'dcf23e   2322   acc41   4212     cdefd'
cleaned_val = lambda v: v if v.isdigit() else ''
[cleaned_val(val) for val in a.split()]

如果字符串是有效的数字,它将给出结果,否则在它们的位置上是空字符串。你知道吗

['', '2322', '', '4212', '']

但是,这只提供字符串。如果要将值转换为整数(将错误的值替换为0),请更改lambda:

convert_to_int = lambda v: int(v) if v.isdigit() else 0

[convert_to_int(val) for val in a.split()]

您的新结果将是所有有效整数:

[0, 2322, 0, 4212, 0]

编译regex以获得性能,拆分字符串以获得正确性

import re
regex = re.compile(r'.*\D+.*')
def my_parse_fun(line):
    return [regex.sub('', emt) for emt in line.split()]

从阿希普的回答来看,你也可以

[val if val.isdigit() else '' for val in line.split()]

使用regex

import re
def covert_string_to_blank(_str):
    return ['' if re.findall("[a-zA-Z]+", c) else c for c in _str.split()]

或者使用isalpha

def convert_string_to_blank(_str):
    return ['' if any(c.isalpha() for c in s) else s for s in _str.split()]

相关问题 更多 >

    热门问题