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凭借其简洁易学的特点,成为普通人提升效率、解决日常问题的得力工具。无论是自动化重复任务、处理数据,还是开发个...
你 发表评论:
欢迎- 一周热门
-
-
python 3.8调用dll - Could not find module 错误的解决方法
-
加密Python源码方案 PyArmor(python项目源码加密)
-
Python3.8如何安装Numpy(python3.6安装numpy)
-
大学生机械制图搜题软件?7个受欢迎的搜题分享了
-
编写一个自动生成双色球号码的 Python 小脚本
-
免费男女身高在线计算器,身高计算公式
-
将python文件打包成exe程序,复制到每台电脑都可以运行
-
Python学习入门教程,字符串函数扩充详解
-
Python数据分析实战-使用replace方法模糊匹配替换某列的值
-
Python进度条显示方案(python2 进度条)
-
- 最近发表
-
- 使用 Python 在 Excel 中创建、引用、导出、更新和删除命名范围
- 完整保留公式:如何将Excel文件导出为包含公式的XML文件
- 「Python数据分析」Pandas数据处理,导入导出Excel数据文件
- Python 自动化办公 | 将 Word 表格转为 Excel
- Python 数据分析——利用Pandas进行分组统计
- python数据分析:介绍pandas库的数据类型Series和DataFrame
- 使用DataFrame计算两列的总和和最大值_[python]
- 8-Python内置函数
- Python中函数式编程函数: reduce()函数
- 万万没想到,除了香农计划,Python3.11竟还有这么多性能提升
- 标签列表
-
- python计时 (54)
- python安装路径 (54)
- python类型转换 (75)
- python进度条 (54)
- python的for循环 (56)
- python串口编程 (60)
- python写入txt (51)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python字典增加键值对 (53)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python qt (52)
- python人脸识别 (54)
- python斐波那契数列 (51)
- python多态 (60)
- python命令行参数 (53)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- centos7安装python (53)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)