Python基础进阶之路(五)之字符串

字符串

字符串的定义

字符串 就是 一串字符,是编程语言中表示文本的数据类型

在 Python 中可以使用 一对双引号 " 或者 一对单引号 ‘ 定义一个字符串

虽然可以使用 \" 或者 \‘ 做字符串的转义,但是在实际开发中:

  • 如果字符串内部需要使用 ",可以使用 ‘ 定义字符串
  • 如果字符串内部需要使用 ‘,可以使用 " 定义字符串

可以使用 索引 获取一个字符串中 指定位置的字符,索引计数从 0 开始

也可以使用 for 循环遍历 字符串中每一个字符

大多数编程语言都是用 " 来定义字符串

string = "Hello Python"
?
for c in string:
    print(c)

字符串的常用操作

定义一个 字符串,例如:hello_str = ""

字符串 能够使用的 方法 如下:

hello_str.capitalize    hello_str.isidentifier  hello_str.rindex
hello_str.casefold      hello_str.islower       hello_str.rjust
hello_str.center        hello_str.isnumeric     hello_str.rpartition
hello_str.count         hello_str.isprintable   hello_str.rsplit
hello_str.encode        hello_str.isspace       hello_str.rstrip
hello_str.endswith      hello_str.istitle       hello_str.split
hello_str.expandtabs    hello_str.isupper       hello_str.splitlines
hello_str.find          hello_str.join          hello_str.startswith
hello_str.format        hello_str.ljust         hello_str.strip
hello_str.format_map    hello_str.lower         hello_str.swapcase
hello_str.index         hello_str.lstrip        hello_str.title
hello_str.isalnum       hello_str.maketrans     hello_str.translate
hello_str.isalpha       hello_str.partition     hello_str.upper
hello_str.isdecimal     hello_str.replace       hello_str.zfill
hello_str.isdigit       hello_str.rfind

提示:正是因为 python 内置提供的方法足够多,才使得在开发时,能够针对字符串进行更加灵活的操作!应对更多的开发需求!

1) 判断类型 - 9


方法


说明


string.isspace()


如果 string 中只包含空白符,如 空格 \t \n,则返回 True


string.isalnum()


如果 string 至少有一个字符并且所有字符都是字母或数字则返回 True


string.isalpha()


如果 string 至少有一个字符并且所有字符都是字母则返回 True


string.isdecimal()


如果 string 只包含数字则返回 True,全角数字


string.isdigit()


如果 string 只包含数字则返回 True,全角数字、⑴、\u00b2


string.isnumeric()


如果 string 只包含数字则返回 True,全角数字,汉字数字


string.istitle()


如果 string 是标题化的(每个单词的首字母大写)则返回 True


string.islower()


如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True


string.isupper()


如果 string 中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True

2) 查找和替换 - 7


方法


说明


string.startswith(str)


检查字符串是否是以 str 开头,是则返回 True


string.endswith(str)


检查字符串是否是以 str 结束,是则返回 True


string.find(str, start=0, end=len(string))


检测 str 是否包含在 string 中,如果 start 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回 -1


string.rfind(str, start=0, end=len(string))


类似于 find(),不过是从右边开始查找


string.index(str, start=0, end=len(string))


跟 find() 方法类似,不过如果 str 不在 string 会报错(区别)


string.rindex(str, start=0, end=len(string))


类似于 index(),不过是从右边开始


string.replace(old_str, new_str, num=string.count(old))


把 string 中的 old_str 替换成 new_str,如果 num 指定,则替换不超过 num 次

3) 大小写转换 - 5


方法


说明


string.capitalize()


把字符串的第一个字符大写


string.title()


把字符串的每个单词首字母大写


string.lower()


转换 string 中所有大写字符为小写


string.upper()


转换 string 中的小写字母为大写


string.swapcase()


翻转 string 中的大小写

4) 文本对齐 - 3


方法 第二个参数可选填充的字符


说明


string.ljust(width)


返回一个原字符串左对齐,并使用空格填充至长度 width 的新字符串


string.rjust(width)


返回一个原字符串右对齐,并使用空格填充至长度 width 的新字符串


string.center(width)


返回一个原字符串居中,并使用空格填充至长度 width 的新字符串

5) 去除空白字符 - 3


方法


说明


string.lstrip()


截掉 string 左边(开始)的空白字符


string.rstrip()


截掉 string 右边(末尾)的空白字符


string.strip()


截掉 string 左右两边的空白字符

6) 拆分和连接 - 5


方法


说明


string.partition(str)


把字符串 string 分成一个 3 元素的元组 (str前面, str, str后面)


string.rpartition(str)


类似于 partition() 方法,不过是从右边开始查找


string.split(str="", num)


以 str 为分隔符拆分 string,如果 num 有指定值,则仅分隔 num + 1 个子字符串,str 默认包含 ‘\r‘, ‘\t‘, ‘\n‘ 和空格,返回为切分后的列表


string.splitlines()


按照行(‘\r‘, ‘\n‘, ‘\r\n‘)分隔,返回一个包含各行作为元素的列表


string.join(list_name)


以 string 作为分隔符,将 list_name 中所有的元素(的字符串表示)合并为一个新的字符串

字符串的切片

切片 方法适用于 字符串、列表、元组

切片 使用 索引值 来限定范围,从一个大的 字符串 中 切出 小的 字符串

列表 和 元组 都是 有序 的集合,都能够 通过索引值 获取到对应的数据

字典 是一个 无序 的集合,是使用 键值对 保存数据

字符串[开始索引:结束索引:步长]

注意:

指定的区间属于 左闭右开 型 [开始索引, 结束索引)  =>  开始索引 >= 范围 < 结束索引

从 起始 位开始,到 结束位的前一位 结束(不包含结束位本身)

从头开始,开始索引 数字可以省略,冒号不能省略

到末尾结束,结束索引 数字可以省略,冒号不能省略

步长默认为 1,如果连续切片,数字和冒号都可以省略

索引的顺序和倒序

在 Python 中不仅支持 顺序索引,同时还支持 倒序索引

所谓倒序索引就是 从右向左 计算索引

最右边的索引值是 -1,依次递减

演练需求

num_str = "0123456789"
?
# 1. 截取从 2 ~ 5 位置 的字符串
print(num_str[2:6])
# 2. 截取从 2 ~ `末尾` 的字符串
print(num_str[2:])
?
# 3. 截取从 `开始` ~ 5 位置 的字符串
print(num_str[:6])
?
# 4. 截取完整的字符串
print(num_str[:])
?
# 5. 从开始位置,每隔一个字符截取字符串
print(num_str[::2])
?
# 6. 从索引 1 开始,每隔一个取一个
print(num_str[1::2])
?
# 倒序切片
# -1 表示倒数第一个字符
print(num_str[-1])
?
# 7. 截取从 2 ~ `末尾 - 1` 的字符串
print(num_str[2:-1])
?
# 8. 截取字符串末尾两个字符
print(num_str[-2:])

# 9. 字符串的逆序
print(num_str[::-1])

公共方法

Python 内置函数

Python 包含了以下内置函数:


函数


描述


备注


len(item)


计算容器中元素个数

 

del(item)


删除变量


del 有两种方式


max(item)


返回容器中元素最大值


如果是字典,只针对 key 比较


min(item)


返回容器中元素最小值


如果是字典,只针对 key 比较


cmp(item1, item2)


比较两个值,-1 小于/0 相等/1 大于


Python 3.x 取消了 cmp 函数

注意

字符串 比较符合以下规则: "0" < "A" < "a"

切片


描述


Python 表达式


结果


支持的数据类型


切片


"0123456789"[::-2]


"97531"


字符串、列表、元组

切片 使用 索引值 来限定范围,从一个大的 字符串 中 切出 小的 字符串

列表 和 元组 都是 有序 的集合,都能够 通过索引值 获取到对应的数据

字典 是一个 无序 的集合,是使用 键值对 保存数据

运算符


运算符


Python 表达式


结果


描述


支持的数据类型


+


[1, 2] + [3, 4]


[1, 2, 3, 4]


合并


字符串、列表、元组


*


["Hi!"] * 4


[‘Hi!‘, ‘Hi!‘, ‘Hi!‘, ‘Hi!‘]


重复


字符串、列表、元组


in


3 in (1, 2, 3)


True


元素是否存在


字符串、列表、元组、字典


not in


4 not in (1, 2, 3)


True


元素是否不存在


字符串、列表、元组、字典


> >= == < <=


(1, 2, 3) < (2, 2, 3)


True


元素比较


字符串、列表、元组

注意

in 在对 字典 操作时,判断的是 字典的键

in 和 not in 被称为 成员运算符

成员运算符

成员运算符用于 测试 序列中是否包含指定的 成员


运算符


描述


实例


in


如果在指定的序列中找到值返回 True,否则返回 False


3 in (1, 2, 3) 返回 True


not in


如果在指定的序列中没有找到值返回 True,否则返回 False


3 not in (1, 2, 3) 返回 False

注意:在对 字典 操作时,判断的是 字典的键

完整的 for 循环语法

在 Python 中完整的 for 循环 的语法如下:

for 变量 in 集合:
    循环体代码
else:
    没有通过 break 退出循环,循环结束后,会执行的代码

应用场景

在 迭代遍历 嵌套的数据类型时,例如 一个列表包含了多个字典

需求:要判断 某一个字典中 是否存在 指定的 值

如果 存在,提示并且退出循环

如果 不存在,在 循环整体结束 后,希望 得到一个统一的提示

students = [
    {"name": "张三",
     "age": 20,
     "gender": True,
     "height": 1.7,
     "weight": 75.0},
    {"name": "小美",
     "age": 19,
     "gender": False,
     "height": 1.6,
     "weight": 45.0},
]?
find_name = "张三"

for stu_dict in students:

    print(stu_dict)
    # 判断当前遍历的字典中姓名是否为find_name
    if stu_dict["name"] == find_name:
        print("找到了")
?
        # 如果已经找到,直接退出循环,就不需要再对后续的数据进行比较
        break
?
else:
    print("没有找到")
?
print("循环结束")

?

原文地址:https://www.cnblogs.com/yqy66/p/10158953.html

时间: 2024-10-11 06:07:56

Python基础进阶之路(五)之字符串的相关文章

Python基础进阶之路(四)之元组、字典和字符串

元组 元组的定义 Tuple(元组)与列表类似,不同之处在于元组的 元素不能修改 元组 表示多个元素组成的序列 元组 在 Python 开发中,有特定的应用场景 用于存储 一串 信息,数据 之间使用 , 分隔 元组用 () 定义 元组的 索引 从 0 开始 索引 就是数据在 元组 中的位置编号 原文地址:https://www.cnblogs.com/yqy66/p/10158719.html

Python基础学习笔记(五)常用字符串内建函数

参考资料: 1. <Python基础教程> 2. http://www.runoob.com/python/python-strings.html 3. http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000 Python字符串内建函数同样支持Unicode,常用函数如下表: 方法 描述 string.capitalize() 把字符串的第一个字符大写 string.center(wi

Python基础教程(第五章 条件、循环和其他语句)

本文内容全部出自<Python基础教程>第二版,在此分享自己的学习之路. ______欢迎转载:http://www.cnblogs.com/Marlowes/p/5329066.html______ Created on Xu Hoo 读者学到这里估计都有点不耐烦了.好吧,这些数据结构什么的看起来都挺好,但还是没法用它们做什么事,对吧? 下面开始,进度会慢慢加快.前面已经介绍过了几种基本语句(print语句.import语句.赋值语句).在深入介绍条件语句和循环语句之前,我们先来看看这几种基

PJzhang:python基础进阶的10个疗程-one

猫宁!!! 课程导学 北京理工大学 国家精品在线开放课程 零基础.大学水平 100行左右的python可以做很多事情 编程是基本技能,体会思维 时间成本和收益的关系 每周5个小时 https://python123.io,实践项目 在线课程.在线实践.离线资料 完整的python基础语法体系 16个优秀实践案例 考核不是目的,但是可以检测学习的效果 每周练习题,阶段性测验 零碎时间+完整时间 跟进度,不断实践 毛主席-实践论 编程能力傍身 感性认识,理性学习 各种小说中人物 的频次以及出场顺序

PJzhang:python基础进阶的10个疗程-two

猫宁!!! 第2节:python基本图形绘制 保留字是python基础语法的支撑 默写python代码是件挺恐怖的事情!!! 2008年android操作系统诞生 计算时代 编程语言也是一个江湖 C语言希望编程者理解计算机系统结构 java语言解决了跨平台问题,面向对象,理解主体与客体的关系 VB语言适合桌面应用开发,理解交互逻辑 python语言理解问题求解 不同语言有不同的设计初心,有不同的时代背景 python语法简洁 第三方库,开放共享,生态高产 工具决定思维,工具变革 机器语言是二进制

python基础学习之路No.2 数据类型

python中常见的数据类型有:整数.浮点数.字符串.列表.元组.字典 python相较其他语言,可以省略了声明,可以直接定义赋值使用. 例如: a=12 就相当于 其他语言中的  int a=12  省略的声明数据类型的int ?下面举例定义各类型的变量: 1.定义一个整数(int) a = 1 2.定义一个浮点型(float) b = 1.2 3.定义一个字符串(string) c = "hello"   (注:python中没有单引号双引号的区分,即还可写成:c = 'hello

01月05日 三周四次【Python基础进阶】

1.8 递归列出目录里的文件1.9 匿名函数 1.8 递归列出目录里的文件 #### 遍历目录里的文件(不支持子目录文件) import os for i in os.listdir('C:/Users/Administrator/Desktop/技术文档'): print (i) ########################################### #### 目录是否存在 import os d = os.path.isdir('C:/Users/Administrator/

Python基础篇【第五篇】:sed和函数

sed是一个无序且不重复的元素集合 1 class set(object): 2 """ 3 set() -> new empty set object 4 set(iterable) -> new set object 5 6 Build an unordered collection of unique elements. 7 """ 8 def add(self, *args, **kwargs): # real signatu

Python-Day4 Python基础进阶之生成器/迭代器/装饰器/Json &amp; pickle 数据序列化

一.生成器 通过列表生成式,我们可以直接创建一个列表.但是,受到内存限制,列表容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了.所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间.在Python中,这种一边循环一边计算的机制,称为生成器:generator. 要创建一个generator,有很多种