Python初学者须知(3)Python中字符串(Strings)的使用

本系列博客主要针对的是Python初学者。Python语言简洁、强大的特性吸引了越来越多的技术人员将他们的项目转移到Python上。目前,Python已经成为计算机行业最流行的编程语言之一。笔者考虑到Python初学者的多元化(Python学习者可能是对编程感兴趣的中学生、学校刚开课的大学生、或者有转型打算的在职人员),本系列博客将结合实际例子深入浅出的全面讲解Python中的所有核心概念,让你知道Python是如何描述世界的。


        本文是笔者的系列博客《Python初学者须知》的第三篇,主要内容是向读者介绍Python中字符串的使用。

什么是字符串?

字符串是一种常见的数据类型,用于表示文本数据,也是最常使用的数据类型。

使用字符串:

想要使用字符串我们首先要知道怎么创建一个字符串。在Python中,可以使用单引号、双引号或三引号来创建字符串,具体如下:

str1 = '《静夜思》'
str2 = "(唐)李白"
multiline_str = """ 
        床前明月光,
        疑是地上霜。
        举头望明月,
        低头思故乡。"""
print(str1 + str2 + multiline_str)

创建完字符串后我们可以尝试将字符串打印出来:

链接字符串:

在上一个例子中我们在打印输出字符串时不是使用的常规的

str1 = '《静夜思》'
str2 = "(唐)李白"
multiline_str = """ 
        床前明月光,
        疑是地上霜。
        举头望明月,
        低头思故乡。"""
print(str1)
print(str2)
print(multiline_str)

而是使用一个“+”将str1 str2 multiline_str 三个字符串连接起来一起打印,从这里就以看出“+”是一个特别的符号,在Python中“+”不仅可以进行数学运算,也能将字符串连接起来。

复制字符串:

字符串不仅可以连接,也可以进行复制,想要复制字符串需要使用“ * ”符号。复印字符串的具体操作如下:

str1 = 'Python很简单!'
str2 = "我一定可以很快学会Python!"
str3 = str1*5
print(str3)
print(str2*5)

 让我们来看一下程序运行的结果吧!

在这里大家可以清楚的可以看到,笔者在两个地方使用了“*”符号,但可以看见的是在程序运行结束后的效果是相同的。

字符串的访问和切片:

(1)访问:

在许多实际情况下我们需要对程序进行访问或者切片,而这两个操作有一个共同的特点利用字符串的索引进行操作。那么什么是索引呢?

在编程中,索引(Index) 是用于定位数据的一种标识方法。在字符串中,索引是用来指示字符串中特定字符位置的数字。在大多数编程语言中,包括Python,字符串的索引通常从零开始,即第一个字符的索引是0,第二个字符的索引是1,依此类推。

例如,考虑字符串 "Hello":

H   e   l   l   o
0   1   2   3   4

在这里,"H" 的索引是0,"e" 的索引是1,以此类推。

你可以使用索引来访问字符串中特定位置的字符。例如,在Python中:

text = "Hello"
first_char = text[0]  # 获取第一个字符,索引为0
second_char = text[1]  # 获取第二个字符,索引为1
print(first_char)
print(second_char)
print(text[2])  # 获取第三个字符,索引为2
print(text[4])  # 获取第五个字符,索引为4

程序运行结果如下:

需要注意的是,如果试图访问超出字符串长度的索引,会引发 IndexError。例如,如果尝试访问 text[5],由于索引5超过了字符串的长度,将导致错误。

索引不仅适用于字符串,还适用于其他序列类型,如列表和元组。在这些情况下,索引的概念也是类似的。

(2)切片:

在编程中,切片(Slice) 是一种从序列(如字符串、列表、元组等)中获取子序列的方法。切片允许你通过指定起始索引、结束索引和步长来截取序列的一部分。
在Python中,切片的语法为:[start:stop:step],其中:
start:起始索引,包含在切片内。
stop:结束索引,不包含在切片内。
step:步长,表示从起始索引到结束索引的间隔,默认为1

以下是一些切片的使用示例:

text = "Hello, World!"

# 获取前5个字符
substring1 = text[:5]  # 等效于 text[0:5]
print(substring1)  # 输出: Hello

# 获取从索引7到末尾的字符
substring2 = text[7:]
print(substring2)  # 输出: World!

# 获取从索引7到索引11的字符
substring3 = text[7:12]
print(substring3)  # 输出: World

# 以步长2获取字符串
substring4 = text[::2]
print(substring4)  # 输出: Hlo ol!

# 反转字符串
substring5 = text[::-1]
print(substring5)  # 输出: !dlroW ,olleH

以下是程序运行结果:

相信细心的读者已经发现了,笔者在进行切片时明明写的是[0:5]而0、1、2、3、4、5明明是六个索引,但实际“切”下来的却是五个元素。这很好理解,[0:5]的真实含义其实是区间[0 , 5),这是一个左闭右开的区间,其中并不包含5。

另外需要注意的是,切片时不会修改原始序列,而是创建一个新的序列。切片是处理序列数据时非常强大和灵活的工具,它允许你轻松地从序列中提取所需的部分。 

查找字符串:

需要注意的是,切片时不会修改原始序列,而是创建一个新的序列。切片是处理序列数据时非常强大和灵活的工具,它允许你轻松地从序列中提取所需的部分。以下是一些常用的字符串查找方法:

在编程中,查找字符串通常是指在一个字符串中搜索特定子字符串或字符的过程。Python提供了多种方法来执行字符串查找操作。

以下是一些常用的字符串查找方法:

    find() 方法:返回字符串中第一次出现指定子字符串的索引,如果未找到则返回-1。

text = "Hello, World!"
index = text.find("World")
print(index)  # 输出: 7

 

    index() 方法: 类似于 find() 方法,但如果未找到子字符串,它会引发 ValueError

text = "Hello, World!"
try:
    index = text.index("Python")
    print(index)
except ValueError as e:
    print(f"Error: {e}")  # 输出: Error: substring not found

需要读者注意的是,这里出现了一个新的语句,这是错误捕捉语句,读者可以先忽略,笔者会在后续的课程中单独讲解。

        

    count() 方法: 返回子字符串在字符串中出现的次数。

text = "Hello, Hello, World!"
count = text.count("Hello")
print(count)  # 输出: 2

这里可以看到字符串中的Hello出现了两次,所以返回值为2。

    startswith()endswith() 方法: 用于检查字符串是否以指定的子字符串开始或结束。

text = "Hello, World!"
starts_with_hello = text.startswith("Hello")
ends_with_world = text.endswith("Hello")
print(starts_with_hello)  # 输出: True
print(ends_with_world)    # 输出: False

这里的“True”和“False”是新的变量类型,布尔(Boolean)类型,该类型只有真“True”假“False”两种类型,通常用于条件判断和逻辑运算,大家记住就好。

在编程中,替换字符串是指将字符串中的特定子字符串替换为新的字符串。在Python中,有多种方法可以实现字符串的替换操作。

替换字符串:

在编程中,替换字符串是指将字符串中的特定子字符串替换为新的字符串。在Python中,有多种方法可以实现字符串的替换操作。

以下是一些常用的字符串替换方法:

    replace() 方法: 该方法用新的字符串替换原字符串中的指定子字符串。它返回一个新的字符串,原始字符串不变。

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

        使用正则表达式进行替换: re 模块提供了正则表达式支持,可以使用 re.sub() 方法进行替换。

import re

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

字符串的大小写转换: 

字符串的大小写转换是指将字符串中的字母字符从大写转换为小写或从小写转换为大写。在Python中,字符串对象提供了内置的方法来执行这些操作。

以下是一些常用的字符串大小写转换方法:

    lower() 方法: 将字符串中的所有字母字符转换为小写。

text = "HWLLO, WORLD!"
lowercase_text = text.lower()
print(lowercase_text)  # 输出: hello, world!

    upper() 方法: 将字符串中的所有字母字符转换为大写。

text = "Hello, World!"
uppercase_text = text.upper()
print(uppercase_text)  # 输出: HELLO, WORLD!

    capitalize() 方法: 将字符串的第一个字符转换为大写,其余字符转换为小写。

text = "hello, world!"
capitalized_text = text.capitalize()
print(capitalized_text)  # 输出: Hello, world!

    title() 方法: 将字符串中的每个单词的第一个字母转换为大写。

text = "hello world"
title_text = text.title()
print(title_text)  # 输出: Hello World

这些方法允许使用者在字符串中执行不同类型的大小写转换,具体取决于使用者的需求。大小写转换在处理用户输入、规范化数据和字符串比较等场景中很常见。

字符串格式化:

字符串格式化是指将数据插入到字符串中的占位符或模板中,以创建一个新的字符串。在Python中,有多种方法可以进行字符串格式化,其中一些主要的方式包括:

        百分号格式化: 使用 % 运算符,通过指定格式符号插入变量值。

name = "Alice"
age = 30
formatted_str = "My name is %s and I am %d years old." % (name, age)
print(formatted_str)
# 输出: My name is Alice and I am 30 years old.

 

%运算符格式化主要有这几种 %s 字符串格式化  %d 十进制整数格式化  %f 浮点数格式化    %x 和%X 十六进制整数格式化(小写或大写)%o 八进制整数格式化  %c 字符格式化

    str.format() 方法: 使用 {} 占位符,通过 format 方法传递变量值。

name = "Bob"
age = 25
formatted_str = "My name is {} and I am {} years old.".format(name, age)
print(formatted_str)
# 输出: My name is Bob and I am 25 years old.

通过这些简单的例子,希望你对Python的基础有了更深入的了解。创建字符串和对字符串进行操作是编程旅程中的基本技能,也是打下坚实基础的关键一步。

以上就是《Python初学者须知(3)Python中字符串(Strings)的使用》的全部内容。

如有错漏请读者斧正。

 

  • 20
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值