Python 超高频常见字符操作【建议收藏】

2023-09-20 17:37:01


前言

为了巩固所学的知识,作者尝试着开始发布一些学习笔记类的博客,方便日后回顾。当然,如果能帮到一些萌新进行新技术的学习那也是极好的。作者菜菜一枚,文章中如果有记录错误,欢迎读者朋友们批评指正。
(博客的参考源码可以在我主页的资源里找到,如果在学习的过程中有什么疑问欢迎大家在评论区向我提出)

1. 字符串截取

在 Python 中,可以使用切片(slicing)来截取字符串。切片的语法是 string[start:end],其中 start 是截取的起始位置(包含),而 end 是截取的结束位置(不包含)。以下是一些示例:

string = "Hello, World!"

# 截取字符串的前五个字符
substring = string[0:5]
print(substring)  # 输出: Hello

# 截取字符串的第六个字符到倒数第二个字符
substring = string[5:-1]
print(substring)  # 输出: , World

# 截取字符串的最后五个字符
substring = string[-5:]
print(substring)  # 输出: World!

# 截取字符串的所有字符,步长为2
substring = string[::2]
print(substring)  # 输出: Hlo Wrd

# 倒序截取字符串的所有字符
substring = string[::-1]
print(substring)  # 输出: !dlroW ,olleH
  • 请注意,切片操作并不会修改原始字符串,而是返回一个新的截取后的字符串。如果不指定起始位置或结束位置,切片操作将默认使用字符串的开头和结尾作为起始位置和结束位置
  • 此外,还可以使用函数来截取字符串例如 string.split() 可以将字符串拆分为多个子字符串,并返回一个列表还可以使用正则表达式来匹配和提取所需部分的字符串。这里提供的是一种常见的基本方式,而根据具体的需求,可能还有其他更适用的方法。

2. 字符串拼接

在 Python 中,可以使用多种方式进行字符串的连接。下面是一些常用的方法:

  • 使用 + 操作符:可以使用 + 操作符将两个字符串连接在一起。
str1 = 'Hello'
str2 = 'World'
result = str1 + ', ' + str2
print(result)  # 输出: Hello, World
  • 使用 += 操作符:可以使用 += 操作符将一个字符串连接到另一个字符串上,相当于在原始字符串的末尾追加另一个字符串。
str1 = 'Hello'
str1 += ', World'
print(str1)  # 输出: Hello, World
  • 使用 str.join() 方法:是一个字符串方法,用于将多个字符串连接起来,通过指定一个可迭代对象作为参数。语法格式如下:
str.join(iterable)

str 是要用作分隔符的字符串,iterable 是一个可迭代对象,可以是列表、元组、字符串等。

str_list = ['Hello', 'World']
result = ', '.join(str_list)
print(result)  # 输出: Hello, World
  • 使用 str.format() 方法:可以使用 str.format() 方法将一个或多个字符串插入到另一个字符串的特定位置。语法格式如下:
str.format(*args, **kwargs)

其中,str 是要进行格式化的字符串,args 是位置参数(可选),kwargs 是关键字参数(可选)

str1 = 'Hello'
str2 = 'World'
result = '{}, {}'.format(str1, str2)
print(result)  # 输出: Hello, World
  • 使用 f-strings(格式化字符串字面值):f-strings(格式化字符串字面值)是 Python 3.6 引入的一种字符串格式化方法,它提供了一种简洁、直观和易于阅读的方式来将变量、表达式等嵌入到字符串中。f-strings 的语法格式如下:
f"string {expression}"

在这里,string 是普通字符串,而 {expression} 是一个表达式,它会被计算并插入到字符串中。

str1 = 'Hello'
str2 = 'World'
result = f'{str1}, {str2}'
print(result)  # 输出: Hello, World
  • 这些方法中,使用 f-strings 通常是最简洁和推荐的方法。但根据具体的需求和 Python 的版本,选择合适的方法进行字符串连接即可。

3. 字符串搜索

要判断一个字符串是否包含另一个字符串,你可以使用 Python 中的 in 关键字或者字符串的 find() 方法。下面是两种判断字符串包含的方法示例:

  • 方法一:使用 in 关键字进行判断
string = "Hello, World!"

# 使用 `in` 关键字判断是否包含某字符串
if "World" in string:
    print("包含")
else:
    print("不包含")

在上述示例中,我们使用 in 关键字判断字符串 “World” 是否存在于变量 string 中。如果存在,则输出 “包含”;否则,输出 “不包含”。

  • 方法二:使用 find() 方法进行判断
string = "Hello, World!"

# 使用 `find()` 方法判断是否包含某字符串
if string.find("World") != -1:
    print("包含")
else:
    print("不包含")

在上述示例中,我们使用字符串的 find() 方法查找子字符串 “World” 在变量 string 中的位置。如果返回的索引不为 -1,则说明存在子字符串,输出 “包含”;否则,输出 “不包含”。
两种方法的选择取决于你具体的需求,in 关键字更简洁直观,而 find() 方法可以获取匹配的位置信息。

4. 字符串格式化

字符串格式化是一种将变量或数据插入到字符串中的方法,以创建具有特定格式的文本。在Python中,字符串格式化可以通过多种方式实现。

1. 百分号(%)操作符
一种常用的字符串格式化方式是使用百分号(%)操作符。这种方法使用占位符来表示要插入的变量,并在%操作符后面提供相应的值。例如:

name = "Alice"
age = 25
message = "My name is %s and I am %d years old." % (name, age)
print(message)

输出结果将是:

My name is Alice and I am 25 years old.

在上面的例子中,%s是字符串占位符,%d是整数占位符。%操作符后的括号中依次提供了要插入的变量(name和age)。

2. python字符串格式化符号:

符 号描述
%c格式化字符及其ASCII码
%s格式化字符串
%d格式化整数
%u格式化无符号整型
%o格式化无符号八进制数
%x格式化无符号十六进制数
%X格式化无符号十六进制数(大写)
%f格式化浮点数字,可指定小数点后的精度
%e用科学计数法格式化浮点数
%E作用同%e,用科学计数法格式化浮点数
%g%f和%e的简写
%G%f 和 %E 的简写
%p用十六进制数格式化变量的地址

3. 格式化操作符辅助指令:

符号功能
*定义宽度或者小数点精度
-用做左对齐
+在正数前面显示加号( + )
< sp >在正数前面显示空格
#在八进制数前面显示零(‘0’),在十六进制前面显示’0x’或者’0X’(取决于用的是’x’还是’X’)
0显示的数字前面填充’0’而不是默认的空格
%‘%%‘输出一个单一的’%’
(var)映射变量(字典参数)
m.n.m 是显示的最小总宽度,n 是小数点后的位数(如果可用的话)

4. format方法

另一种字符串格式化的方式是使用 format() 方法。这种方法使用 {} 和 : 来代替以前的 % 。
format 函数可以接受不限个参数,位置可以不按顺序。并使用format()方法提供要插入的值。例如:

name = "Bob"
age = 30
message = "My name is {} and I am {} years old.".format(name, age)
print(message)

输出结果将是:

My name is Bob and I am 30 years old.

在这个例子中,大括号{}表示占位符,format()方法中依次提供了要插入的变量。

5. 数字格式化

下表展示了 str.format() 格式化数字的多种方法:

>>> print("{:.2f}".format(3.1415926))
3.14
数字格式输出描述
3.1415926{:.2f}3.14保留小数点后两位
3.1415926{:+.2f}+3.14带符号保留小数点后两位
-1{:-.2f}-1.00带符号保留小数点后两位
2.71828{:.0f}3不带小数
5{:0>2d}05数字补零 (填充左边, 宽度为2)
5{:x<4d}5xxx数字补x (填充右边, 宽度为4)
10{:x<4d}10xx数字补x (填充右边, 宽度为4)
1000000{:,}1,000,000以逗号分隔的数字格式
0.25{:.2%}25.00%百分比格式
1000000000{:.2e}1.00e+09指数记法
13{:>10d}13右对齐 (默认, 宽度为10)
13{:<10d}13左对齐 (宽度为10)
13{:^10d}13中间对齐 (宽度为10)
11‘{:b}’.format(11)‘{:d}’.format(11)‘{😮}’.format(11)‘{:x}’.format(11)‘{:#x}’.format(11)‘{:#X}’.format(11)1011 11 13 b 0xb 0XB进制
  • ^, <, > 分别是居中、左对齐、右对齐,后面带宽度, : 号后面带填充的字符,只能是一个字符,不指定则默认是用空格填充。

  • + 表示在正数前显示 +,负数前显示 -; (空格)表示在正数前加空格

  • b、d、o、x 分别是二进制、十进制、八进制、十六进制。

  • 此外我们可以使用大括号 {} 来转义大括号,如下实例:
    实例

#!/usr/bin/python
# -*- coding: UTF-8 -*-
 
print ("{} 对应的位置是 {{0}}".format("runoob"))

输出结果为:

runoob 对应的位置是 {0}

6. f-string方法

还有一种更简洁的字符串格式化方式是使用 f-string(格式化字符串字面值)。这种方法使用在字符串前加上字母"f",并在大括号中直接引用变量。例如:

name = "Charlie"
age = 35
message = f"My name is {name} and I am {age} years old."
print(message)

输出结果将是:

My name is Charlie and I am 35 years old.

f-string直接在大括号{}中引用了变量name和age,无需使用额外的格式化方法。
以上是Python中常用的字符串格式化方法。根据具体的需求,可以选择使用其中一种或多种方式来实现字符串格式化。

5. 字符串替换

在 Python 中,有几种常见的方法用于字符串替换。下面是其中几种常用的方法:

1.replace() 方法:

该方法用于替换字符串中的指定子字符串为新的字符串。

   text = "Hello, World!"
   new_text = text.replace("World", "Python")
   print(new_text)  # 输出:Hello, Python!

2.re.sub() 方法:

该方法使用正则表达式进行字符串替换。

   import re

   text = "Hello, World!"
   new_text = re.sub(r"World", "Python", text)
   print(new_text)  # 输出:Hello, Python!

3.str.translate() 方法:

该方法使用转换表进行字符替换。可以使用 str.maketrans() 函数创建转换表。

   table = str.maketrans("W", "P")
   text = "Hello, World!"
   new_text = text.translate(table)
   print(new_text)  # 输出:Hello, Porld!

6. 字符串去除空格

在 Python 中,有几种方法可以去除字符串中的空格。以下是几种常见的方法:

1.strip() 方法:

该方法用于去除字符串开头和结尾的空格。

   text = "   Hello, World!   "
   stripped_text = text.strip()
   print(stripped_text)  # 输出:Hello, World!

2.lstrip() 和 rstrip() 方法:

lstrip() 方法用于去除字符串开头的空格,rstrip() 方法用于去除字符串结尾的空格。

   text = "   Hello, World!   "
   left_stripped_text = text.lstrip()
   right_stripped_text = text.rstrip()
   print(left_stripped_text)  # 输出:Hello, World!   
   print(right_stripped_text)  # 输出:   Hello, World!

3.replace() 方法:

该方法可以用来替换空格字符为空字符串。

   text = "   Hello, World!   "
   replaced_text = text.replace(" ", "")
   print(replaced_text)  # 输出:Hello,World!

4.split() 和 join() 方法组合使用:

将字符串拆分成单词列表,再使用空字符串连接单词来移除空格。

   text = "   Hello, World!   "
   words = text.split()
   joined_text = "".join(words)
   print(joined_text)  # 输出:Hello,World!

这些方法可以根据你的需求选择合适的方式去除字符串中的空格。请注意,以上方法都返回新的字符串,原始字符串不会被修改。

7. 字符串截取

在 Python 中,有几种方法可以对字符串进行分割(拆分)操作。以下是几种常见的方法:

1.split() 方法:

该方法根据指定的分隔符将字符串拆分成子字符串,并返回一个列表。

   text = "Hello, World!"
   words = text.split(",")  # 使用逗号作为分隔符
   print(words)  # 输出:['Hello', ' World!']

2.rsplit() 方法:

该方法与 split() 方法类似,但从字符串的末尾开始进行拆分。

   text = "Hello, World!"
   words = text.rsplit(",", 1)  # 从右侧使用逗号作为分隔符拆分一次
   print(words)  # 输出:['Hello', ' World!']

3.splitlines() 方法:

该方法按照换行符 \n 分割字符串,并返回一个包含各行内容的列表。

   text = "Hello\nWorld\nPython"
   lines = text.splitlines()
   print(lines)  # 输出:['Hello', 'World', 'Python']

4.正则表达式分割:

使用 re.split() 函数可以根据正则表达式进行字符串分割。

   import re

   text = "Hello, World! Python"
   words = re.split(r"\W+", text)  # 使用非字母数字字符作为分隔符
   print(words)  # 输出:['Hello', 'World', 'Python']

这些方法可以根据具体需求选择合适的方式来对字符串进行分割操作。请注意,以上方法返回的是包含拆分后子字符串的列表。

8. 字符串反转

在 Python 中,可以使用几种方法来反转字符串。以下是其中几种常见的方法:

1.使用切片操作:

  text = "Hello, World!"
   reversed_text = text[::-1]
   print(reversed_text)  # 输出:!dlroW ,olleH

2.使用 reversed() 函数与 join() 方法:

   text = "Hello, World!"
   reversed_text = "".join(reversed(text))
   print(reversed_text)  # 输出:!dlroW ,olleH

3.使用循环遍历法:

   text = "Hello, World!"
   reversed_text = ""
   for char in text:
       reversed_text = char + reversed_text
   print(reversed_text)  # 输出:!dlroW ,olleH

这些方法都可以用来反转字符串,你可以根据自己的喜好和需求选择其中一种。需要注意的是,以上方法返回的是一个新的反转后的字符串,原始字符串本身并没有被修改。

总结

欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下。
(博客的参考源码可以在我主页的资源里找到,如果在学习的过程中有什么疑问欢迎大家在评论区向我提出)

更多推荐

在Kubernetes上安装和配置Istio:逐步指南,展示如何在Kubernetes集群中安装和配置Istio服务网格

🌷🍁博主猫头虎带您GotoNewWorld.✨🍁🦄博客首页——猫头虎的博客🎐🐳《面试题大全专栏》文章图文并茂🦕生动形象🦖简单易学!欢迎大家来踩踩~🌺🌊《IDEA开发秘籍专栏》学会IDEA常用操作,工作效率翻倍~💐🌊《100天精通Golang(基础入门篇)》学会Golang语言,畅玩云原生,走遍大

基于 STM32自研多任务+SpringBoot+Vue 农业大棚智能调光系统

工作以后常常容易感到疲于奔命,即使在周末也没有得到高质量的休息。打工人/学生党如何过周末?你有哪些延长周末和下班时间的好方法吗?-方法就是多积累,多发博客,将感悟全写出来!!,接下来我给大家展示一个课程设计:源码和硬件端代码就不与展示了,在该博客的资源绑定中,大家如果有兴趣可以参考一下。前后端代码保存在我的资源中我的主

STM32 cubemx配置USART DMA传输

文章目录前言一、DMA概念二、STM32DMA数据手册分析3.DMA模式介绍4.cubemx配置总结前言本篇文章来讲解DMA的概念,并使用DMA来进行串口的数据收发。一、DMA概念DMA(DirectMemoryAccess,直接内存访问)是一种计算机系统的技术,允许外部设备(如硬盘驱动器、网络适配器或图形卡)直接与计

大数据与人工智能的未来已来

大数据与人工智能的定义大数据:大数据指的是规模庞大、复杂性高、多样性丰富的数据集合。这些数据通常无法通过传统的数据库管理工具来捕获、存储、管理和处理。大数据的特点包括"3V":大量(Volume):大数据集合包含大量的数据,通常是以TB(千兆字节)或PB(百万兆字节)为单位。多样性(Variety):大数据包括各种类型

【无标题】

更多技术交流、求职机会,欢迎关注字节跳动数据平台微信公众号,回复【1】进入官方交流群背景介绍Notebook解决的问题部分任务类型(python、spark等)在创建配置阶段,需要进行分步调试;由于探索查询能力较弱,部分用户只能通过其他平台or其他途径进行开发调试,但部署到Dorado时,又发现行为不一致等问题(运行环

服务器管理

腾讯云服务器相关管理linux下安装python3linux自带2.x,有时候需要2.x执行一些工具,开发的时候又想用p3,就需要同时装python2和python3依次执行以下命令sshxxx@xx.xx.xx.xx#进入linux服务器su#输入密码,如果不知道管理员账户但拥有sudo权限,下面所有命令前缀都跟su

Kafka消息发送可靠性分析

ApacheKafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者和生产者之间的所有实时数据。Kafka的主要特性包括:高吞吐量、可扩展性、持久性、分布式、可容错等。这些特性使得Kafka成为大规模数据处理和实时数据分析的理想选择。然而,关于Kafka的一个常见问题是其消息发送的可靠性。下面我们将详细分析K

504 错误码排查

当出现504错误码时,表示请求超时,服务器无法及时响应请求,需要检查下应用是否有什么耗时的操作,比如是否出现了SQL慢查询、是否接口发生死循环、是否出现死锁等,同时需要关注服务器系统负载高不高。网络异常接口原本好好的,突然出现超时,最常见的原因可能是网络出现异常,比如:偶然的网络抖动,或者是带宽被占满了。网络抖动:大多

Jmeter系列-定时器Timers的基本介绍(11)

简介JMeter中的定时器(Timer)是一种重要的元件,用于模拟用户在不同时间间隔内发送请求的场景。通过使用定时器,可以模拟负载、并发和容量等不同情况下的请求发送频率。使用定时器可以在取样器下添加定时器,这样定时器只会作用于当前取样器也可以在线程组下添加多个定时器,统计定时器的总和,然后作用于线程组下的所有取样器定时

Android studio 快捷键

目录Ctrl+N搜索指定的Java类Ctrl+F查找文本Alt+Enter修复代码错误Ctrl+Alt+L格式化代码Ctrl+D复制当前行或选中的内容Ctrl+W逐渐增加当前选中的范围Ctrl+Shift+-折叠所有代码Ctrl+Shift++展开所有代码Ctrl+B查看定义Ctrl+Alt+B查看实现Ctrl+Alt

系统架构设计师(第二版)学习笔记----信息系统基础

【原文链接】系统架构设计师(第二版)学习笔记----信息系统基础文章目录一、信息系统概述1.1信息系统的5个基本功能1.2信息系统发展阶段1.3初始阶段的主要特点1.4传播阶段的主要特点1.5控制阶段的主要特点1.6集成阶段的主要特点1.7信息系统的种类1.8企业主要使用的信息化系统1.9信息系统的生命周期阶段1.10

热文推荐