使用Python 字符串 `replace` 遇到的小问题

简介: 使用Python 字符串 replace 遇到的小问题场景:需要replace一串字符串中的8个地方,使用8次replace方法。报错信息:TypeError: expected a string or other character buffer object我本以为是使用replace过多次导致的某些地方不兼容。

使用Python 字符串 replace 遇到的小问题

场景:需要replace一串字符串中的8个地方,使用8次replace方法。

报错信息:

TypeError: expected a string or other character buffer object

我本以为是使用replace过多次导致的某些地方不兼容。比如原本字符串中找到多个需要匹配的项,可是我没给够待替换的项这种情况。code1

s = s = ['xxx','xx','xxx','xx','33554111720048','xx','xxxx','xxx.cn']

ht = data.replace('0000',s[0]).replace('1111',s[1]).replace('2222',s[2]).replace('3333',s[3]).replace('4444',s[4]).replace('5555',s[5]).replace('6666',s[6]).replace('7777',s[7])

注意到s[4]是个很长的数字,我本以为这种series的type都是object,既没有去管。尝试code2

ht = dict()
for i in range(8):
    if i == 0:
        ht[i] = data.replace('l%d%d%d'%(i,i,i),s[i])
    else:
        ht[i] = ht[i-1].replace('l%d%d%d'%(i,i,i),s[i])

这样最后`ht[7]就是我想要的,然而还是一个报错信息。

解决办法

(这是数字过长写不进去引起的?)
code1中的replace("4444",str(s[4]))即可。

目录
相关文章
|
2月前
|
Python
Python中的f-string:更优雅的字符串格式化
Python中的f-string:更优雅的字符串格式化
324 100
|
2月前
|
开发者 Python
Python中的f-string:高效字符串格式化的利器
Python中的f-string:高效字符串格式化的利器
439 99
|
2月前
|
Python
Python中的f-string:更优雅的字符串格式化
Python中的f-string:更优雅的字符串格式化
|
2月前
|
开发者 Python
Python f-strings:更优雅的字符串格式化技巧
Python f-strings:更优雅的字符串格式化技巧
|
2月前
|
开发者 Python
Python f-string:高效字符串格式化的艺术
Python f-string:高效字符串格式化的艺术
|
2月前
|
Python
使用Python f-strings实现更优雅的字符串格式化
使用Python f-strings实现更优雅的字符串格式化
|
3月前
|
Python
Python中的f-string:更简洁的字符串格式化
Python中的f-string:更简洁的字符串格式化
287 92
|
1月前
|
存储 Java 索引
(Python基础)新时代语言!一起学习Python吧!(二):字符编码由来;Python字符串、字符串格式化;list集合和tuple元组区别
字符编码 我们要清楚,计算机最开始的表达都是由二进制而来 我们要想通过二进制来表示我们熟知的字符看看以下的变化 例如: 1 的二进制编码为 0000 0001 我们通过A这个字符,让其在计算机内部存储(现如今,A 字符在地址通常表示为65) 现在拿A举例: 在计算机内部 A字符,它本身表示为 65这个数,在计算机底层会转为二进制码 也意味着A字符在底层表示为 1000001 通过这样的字符表示进行转换,逐步发展为拥有127个字符的编码存储到计算机中,这个编码表也被称为ASCII编码。 但随时代变迁,ASCII编码逐渐暴露短板,全球有上百种语言,光是ASCII编码并不能够满足需求
145 4
|
3月前
|
数据采集 存储 数据库
Python字符串全解析:从基础操作到高级技巧
Python字符串处理详解,涵盖基础操作、格式化、编码、正则表达式及性能优化等内容,结合实际案例帮助开发者系统掌握字符串核心技能,提升文本处理与编程效率。
412 0