Python 3.7。x windows上。 我在使用字典中的string.replace()时遇到了问题,问题是字典值中有星号。 快速上下文:我们收集野外植物物种的数据,为了使事情更快,我们使用7个字符的“代码”和相应的完整的科学名称。如果是报告用的非本地物种,名字后面会有一个星号。例如:Cencili = Cenchrus ciliaris*或Eucpopu = Eucalyptus populnea 字段数据如下(在panda df中):
FieldData
Location Species
1 Site_1 Uromosa, Chlgaya, Cencili
2 Site_2 Cencili, Sclmuri, Eucpopu, Glaaris, Atahemi
词汇表/定义表是这样的(在转换成字典之前):
SpeciesList
Code Scientific
1 Cencili Cenchrus ciliaris*
2 Eucpopu Eucalyptus populnea
我尝试:
import pandas as pd
import csv, re
FieldData = pd.read_csv('FieldDataPath')
SpeciesList = pd.read_csv('SpeciesListPath')
SpeciesDict = dict(zip(SpeciesList.Code, SpeciesList.Scientific))
for k, v in SpeciesDict.items():
FieldData['Species'].replace(k, v, inplace = True, regex = True)
问题是这行得通……排序的。如果regex = True是成功替换的物种代码,但是在科学名称的每个字母之间插入星号。 洛杉矶:
Location Species
870 Site_1 *C*e*n*c*h*r*u*s* *c*i*l*i*a*r*i*s***,* *S*a*l...
如果regex = False,则replace()不起作用,数据保持不变。 如果我从词汇表中删除星号,它可以正常工作,但我需要星号在那里。在这个过程之后,我曾想过要单独标记非本地物种,但我想我也会遇到同样的问题。 我知道这与正则表达式有关,也知道星号是如何解释的,但我就是想不出来。我到处找,都没找到类似的问题。 长期潜伏者,初次发问者。我希望这个问题符合标准。 问题来源StackOverflow 地址:/questions/59385653/asterisk-issue-in-replace-when-using-a-dictionary-python
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。