百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python字符串(python字符串替换)

off999 2024-09-14 07:07 18 浏览 0 评论

回顾

在上一篇《Python集合详解》中,我们介绍了集合的相关方法,简单回顾一下:

  • 创建集合:{ } 和set()函数两种方式
  • 集合添加元素:setname.add(element)
  • 集合删除元素:setname.remove(element)
  • 清空集合:setname.clear()
  • 集合求交集:& 或 intersection()
  • 集合求并集:| 或 union()
  • 集合求差集:- 或 difference()
  • 复制集合:setname.copy()

这次的主题是Python中很重要的一个数据类型:字符串。

一、字符串切片

从本质上讲,字符串是由多个字符构成的,字符之间是有顺序的,这个顺序号称为索引(index)。

1.获取单个字符

在方括号[ ]中使用索引即可访问对应的字符,具体的语法格式为:

strname[index]

Python 允许从字符串的两端使用索引:

  • 当以字符串的左端(字符串的开头)为起点时,索引是从 0 开始计数的;字符串的第一个字符的索引为 0,第二个字符的索引为 1,第三个字符串的索引为 2 ……以此类推
  • 当以字符串的右端(字符串的末尾)为起点时,索引是从 -1 开始计数的;字符串的倒数第一个字符的索引为 -1,倒数第二个字符的索引为 -2,倒数第三个字符的索引为 -3 ……以此类推
str1 = "life is short,i need PYTHON"
# 字符串查找
print(str1.find('s', 0, -1))  # 查找指定范围内是否存在某字符,是返回下标,不存在返回-1
# 获取单个字符
a = str1[0]  # 第一个字符
b = str1[-1]  # 最后一个字符
print(a)  # 1
print(b)  # N

2.获取多个字符(字符串截取/切片)

使用[ ]除了可以获取单个字符外,还可以指定一个范围来获取多个字符,也就是一个子串或者片段,具体格式为:

strname[start : end : step]

# 获取多个字符(字符串切片)
c = str1[0:3]  # 获取str1的第1个到第3个之间的字符,步长默认为1
d = str1[0:5:2]  # 获取str1的第1个到第5个之间的字符,指定默认为2

二、len():获取对象长度和字节长度

Python 中,要想知道一个对象长度,或者一个字符串占用多少个字节,可以使用 len 函数。len 函数的基本语法格式为:

len(obj)

其中 obj用于指定要进行长度统计的对象,可以是字符串、列表、元组、字典等。 通过使用 encode() 方法,将字符串进行编码后再获取它的字节数。例如,采用 UTF-8 编码方式,计算“人生苦短,我用Python”的字节数,可以执行如下代码:

# 获取对象长度
str2 = "人生苦短,我用PYTHON"
print(len(str2))  # 13
print(len(str2.encode()))  # 27,使用encode()方法转码为字节,一个中文字符占用3个字节

三、join()方法:合并字符串

Python join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串。语法格式:

newstr = str.join(iterable)

此方法中各参数的含义如下:

  • newstr:表示合并后生成的新字符串;
  • str:用于指定合并时的分隔符;
  • iterable:做合并操作的源字符串数据,允许以列表、元组等形式提供。
# 合并字符串
list_a = ['a', 'b', 'c', 'd', 'e']
print("".join(list_a))  # abcde 默认连接符
print("#".join(list_a))  # a#b#c#d#e  指定连接符
# 字符串拼接
str_a = "人生苦短"
str_b = "我用PYTHON"
print(str_a + str_b)  # 人生苦短我用PYTHON
# 字符串追加字符
print(str_b.join(str_a))  # 人我用PYTHON生我用PYTHON苦我用PYTHON短  输出的为无序的字符串

四、split()方法:字符串分隔

# 字符串分隔
str2 = "life is short,i need python"
print(str1.split(' '))  # ['life', 'is', 'short,i', 'need', 'PYTHON']

五、替换与删除指定字符

  • str.replace(old, new,count),替换指定字符(不加count默认全替换)
  • str.replace(old, '',count),将指定字符用空字符代替、从而达到删除的目的(不加count默认全替换)
# 字符串替换指定字符(用大写的LIFE字符代替小写的life)
print(str2.replace('life', 'LIFE'))  # LIFE is short,i need python
# 字符串删除指定字符(用空字符代替字符i,从而达到删除目的)
print(str2.replace('i', ''))  # lfe s short, need python

六、字符串格式化输出

1.来自C语言的%方式

%号格式化字符串的方式继承自古老的C语言,这在很多编程语言都有类似的实现。%s是一个占位符,它仅代表一段字符串,并不是拼接的实际内容。实际的拼接内容在一个单独的%号后面,放在一个元组里。 类似的占位符还有:

  • %d(代表一个整数)
  • %f(代表一个浮点数)
  • %x(代表一个16进制数)

%占位符既是这种拼接方 式的特点,同时也是其限制因为每种占位符都有特定意义,实际使用起来较为麻烦。

# 使用占位符
name = "dang"
age = 5
print("我叫%s,我今年%s岁了" % (name, age))  # 我叫dang,我今年5岁了
print("%d" % (20))  # 八进制  20
print("%o" % (20))  # 十进制  24
print("%x" % (20))  # 十六进制  14

2.format()拼接方式

# format()拼接方式
name1 = "当当"
name2 = "刚刚"
age = 5
print("我叫{},我今年{}岁了".format(name1, age))  # 我叫当当,我今年5岁了
print("我叫{1},我叫{0}".format(name1, name2))  # 使用编号指定顺序  "我叫刚刚,我叫当当"
print("我叫{name},我今年{age}岁了".format(name=name1, age=age))  # 使用变量名指定顺序  "我叫当当,我今年5岁了"

3.f-string方式

f-string方式出自PEP 498(Literal String Interpolation,字面字符串插值),从Python3.6版本引入。其特点是在字符串前加 f 标识,字符串中间则用花括号{}包裹其他字符串变量。

# f-string方式
name3 = "jigang.chen"
age = 28
print(f"我叫{name3},我今年{age}岁了")  # 我叫jigang.chen,我今年28岁了
print(f"a total number is {20 * 2 + 8}")  # 处理表达式   a total number is 48
name = "PYTHON"
print(f"my name is {name.lower()}")  # 处理方法调用   my name is python

七、字符串其他方法

str1 = "life is short,i need PYTHON"
# 计算某个字符出现的次数
print(str1.count('i'))  # 3
# 在指定区间内查找某个字符,并返回该字符的索引
print(str1.find('f', 0, -1))  # 2
# 将字符串全部转换为小写
print(str1.lower())  # life is short,i need python

总结

列表、元组、字符串都是有序序列,而字典、集合都是无序序列,无法通过下标获取元素;

列表、字典、集合都是可变序列,而元组、字符串是不可变序列,一旦创建,就无法更改;

相关推荐

使用 Python 在 Excel 中创建、引用、导出、更新和删除命名范围

Excel中的命名区域是分配给特定单元格区域(如“SalesData”或“Revenue”)的用户定义标识符。通过使用有意义的名称而不是A1:B10等标准单元格引用,命名区域可以更轻松地引用数据...

完整保留公式:如何将Excel文件导出为包含公式的XML文件

Excel中的公式为数据计算提供了强大的支持,而在导出文件时,确保这些公式能被完整保留非常重要。将Excel文件导出为XML格式时,如何确保公式不会丢失?本文将介绍三种有效的方法,帮助您在导出过程中保...

「Python数据分析」Pandas数据处理,导入导出Excel数据文件

数据分析过程,基本上可以通过以下4个步骤来实现。1、数据获取2、数据处理3、数据分析4、数据结果我们首先来看数据获取的这个步骤。现实中,我们面对的大部分数据,基本上大多数都是Excel格式的数据文件。...

Python 自动化办公 | 将 Word 表格转为 Excel

优质文章,第一时间送达!大家好,今天有一个公务员的小伙伴委托我给他帮个忙,大概是有这样一份Word(由于涉及文件私密所以文中的具体内容已做修改)一共有近2600条类似格式的表格细栏,每个栏目包括的信息...

Python 数据分析——利用Pandas进行分组统计

话说天下大势,分久必合,合久必分。数据分析也是如此,我们经常要对数据进行分组与聚合,以对不同组的数据进行深入解读。本章将介绍如何利用Pandas中的GroupBy操作函数来完成数据的分组、聚合以及统计...

python数据分析:介绍pandas库的数据类型Series和DataFrame

安装pandaspipinstallpandas-ihttps://mirrors.aliyun.com/pypi/simple/使用pandas直接导入即可importpandasas...

使用DataFrame计算两列的总和和最大值_[python]

【如果对您有用,请关注并转发,谢谢~~】最近在处理气象类相关数据的空间计算,在做综合性计算的时候,DataFrame针对每列的统计求和、最大值等较为方便,对某行的两列或多列数据进行求和与最大值等的简便...

8-Python内置函数

Python提供了丰富的内置函数,这些函数可以直接使用而无需导入任何模块。以下是一些常用的内置函数及其示例:1-print()1-1-说明输出指定的信息到控制台。1-2-例子2-len()2-1-说...

Python中函数式编程函数: reduce()函数

Python中的reduce()函数是一个强大的工具,它通过连续地将指定的函数应用于序列(如列表)来对序列(如列表)执行累积操作。它是functools模块的一部分,这意味着您需要在使用它之...

万万没想到,除了香农计划,Python3.11竟还有这么多性能提升

众所周知,Python3.11版本带来了较大的性能提升,但是,它具体在哪些方面上得到了优化呢?除了著名的“香农计划”外,它还包含哪些与性能相关的优化呢?本文将带你一探究竟!作者:BeshrKay...

最全python3.11版12类75个内置函数大全

获取全部内置函数:importbuiltins#导入模块yc=[]#异常属性nc=[]#不可调用fn=[]#内置函数defll(ty=builtins):...

软件测试笔试题

测试工程师岗位,3-5年,10-14k1.我司有一款产品,类似TeamViewer,向日葵,mstsc,QQ远程控制产品,一个PC客户端产品,请设想一下测试要点。并写出2.写出常用的SQL语句8条,l...

备战各大互联网巨头公司招聘会,最全Python面试大全,共300题

前言众所周知,越是顶尖的互联网公司在面试这一part的要求就越高,需要你有很好的技术功底、项目经验、一份漂亮的简历,当然还有避免不了的笔试过关。对于Python的工程师来说,全面掌握好有关Python...

经典 SQL 数据库笔试题及答案整理

马上又是金三银四啦,有蛮多小伙伴在跳槽找工作,但对于年限稍短的软件测试工程师,难免会需要进行笔试,而在笔试中,基本都会碰到一道关于数据库的大题,今天这篇文章呢,就收录了下最近学员反馈上来的一些数据库笔...

用Python开发日常小软件,让生活与工作更高效!附实例代码

引言:Python如何让生活更轻松?在数字化时代,编程早已不是程序员的专属技能。Python凭借其简洁易学的特点,成为普通人提升效率、解决日常问题的得力工具。无论是自动化重复任务、处理数据,还是开发个...

取消回复欢迎 发表评论: