前言
字符串是python常用的变量类型,其包括了很多函数方法。本文重点介绍这些方法的使用。
一、认识字符串
在之前的文章提到过,字符串是用单引号或者双引号进行声明。
nam = '张三'
name = "张三"
初次之外也可以使用三引号
name3 = ''' Tom '''
name4 = """ Rose """
a = ''' i am Tom,
nice to meet you! '''
b = """ i am Rose,
nice to meet you! """
三引号支持换行
二、字符串的使用
1.输出
在前篇文章具体提到过输入输出,读者可以翻阅之前文章。
2. 认识下标
下标也可以理解为索引。用来标识位置,下标的作⽤即是通过下标快速找到对应的数据。
正数小标从第一个字母开始,并且以0为起始。负数下标从末尾第一个字母开始,以-1起始。
使用
变量名[下标]
就可以获取特定索引位置的字母。
如:
name="hello,python"
print(name[0]) #结果;z
print(name[-12]) #结果;z
当下标数字超过字符长度时,程序将会报错 :IndexError: string index out of range
利用len()
方法可以直接获取字符长度
name="hello,python"
print(len(name))
#结果为:12
三、切片
1. 切片的定义
切⽚是指对操作的对象截取其中⼀部分的操作。字符串、列表、元组都⽀持切⽚操作。
(列表和元组在后面进行详细介绍)
2. 切片的使用
切片语法: 序列[开始位置下标:结束位置下标:步⻓]
需要注意:
- 不包含结束位置下标对应的数据, 正负整数均可;
- 步⻓是选取间隔,正负整数均可,默认步⻓为1。
以下面代码为例:
name="hello,python"
print(name[1:3:1])
可以这样理解:
从下标为1(字母e)开始截取,截取到下标3(字母l),但不包括下标3的值,每次步长为1.
#所以结果为:
el
接下来对各种情况进行测试:
正数下标时:
name="hello,python"
# 正常截取
print(name[1:3:1])
print(name[1:15:]) #结束下标超出也只能截取全部字符串
# 在非默认值以前的下标数字可以省略,非默认值以后的冒号和数字都可以省略
# 当不写步长时,会取默认值1
print(name[1:3])
# 不写起始下标,默认值为0
print(name[:3:1])
# 不写结束下标
print(name[1::2])
print(name[1::]) # 省略非默认值以后的数字
print(name[1:]) # 省略非默认值以后的冒号和数字,注意1后面的冒号不可以省略
# 不写起始和步长
print(name[:3:])
print(name[:4])
# 只写步长
print(name[::2]) #在非默认值以前的下标数字可以省略,冒号不可以
负数下标时:
name="hello,python"
print(name[5:3:-1]) # 结果为:,o
print(name[::-1]) # 结果为:nohtyp,olleh 这样就可以让字符串进行倒序
print(name[-4:-1:]) # 结果为:tho
注意:
起始下标的默认值为0.,结束下标默认值为字符串长度,步长默认值为1
当步长为正数时候,起始位置的下标数字必须小于结束下标的数字。
当步长为负数时候,起始位置的下标数字必须大于于结束下标的数字。
四、字符串常用方法
1. 查找
(1)find()
查找这个字段是否存在这个字符串中。如果存在则返回第一个符合条件字段开始的下标,不存在则返回-1.
语法:变量名.find(“要查找的字段”,开始位置的下标,结束位置的下标)
例如:
name="hello,python"
find=name.find("llo",1,8)
print(find)
#输出结果为:
2
(2)index()
检测某个⼦串是否包含在这个字符串中,如果在返回这个⼦串开始的位置下标,否则报异常。
注意find()和index()区别。find失败会返回-1,而index()会直接报错。
语法:变量名.index(“要查找的字段”,开始位置的下标,结束位置的下标).
(和find()使用一样)
rfind()
: 和find()功能相同,但查找⽅向为右侧开始。
rindex()
:和index()功能相同,但查找⽅向为右侧开始。
count()
:返回某个⼦串在字符串中出现的次数
2. 修改
修改主要是对字符串内容进行修改,例如:替换某个字符、删除、合并等操作。
由于牵扯的方法很多,作者重点介绍下几个常用方法。
replace()
:替换方法
语法:变量.replace(原来字符串,新字符串,替换次数)
name="hello,hello,hello,hello,hello"
replace1=name.replace("hello", "python")
replace2=name.replace("hello", "python",2)
print(replace1) #输出结果为:python,python,python,python,python
print(replace2) #输出结果为:python,python,hello,hello,hello
替换不会改变原来字符串的内容
split()
会将字符串的某个单词进行切除。
语法:变量.split(分割字符,次数)
name="hello world and itcast and itheima and Python"
split1=name.split("and")
split2=name.split("and",2)
print(split1) #结果为:['hello world ', ' itcast ', ' itheima ', ' Python']
print(split2) #结果为:['hello world ', ' itcast ', ' itheima and Python']
print(name) #结果为:hello world and itcast and itheima and Python
join()
:⽤⼀个字符或⼦串合并字符串,即是将多个字符串合并为⼀个新的字符串。
语法:变量.join(多字符串组成的序列)
list1 = ['chuan', 'zhi', 'bo', 'ke']
t1 = ('aa', 'b', 'cc', 'ddd')
print('_'.join(list1)) # 结果:chuan_zhi_bo_ke
print('...'.join(t1)) # 结果:aa...b...cc...ddd
其他方法:
capitalize()
:将字符串第⼀个字符转换成⼤写。
title()
:将字符串每个单词⾸字⺟转换成⼤写
lower()
:将字符串中⼤写转⼩写。
upper()
:将字符串中⼩写转⼤写。
3. 判断
判断所涉及到的函数返回值为布尔类型,当符合条件时,返回值为true。
startswith()
:检查字符串是否是以指定⼦串开头。
语法:字符串序列.startswith(⼦串, 开始位置下标, 结束位置下标)
endswith()
:检查字符串是否是以指定⼦串结尾
语法:字符串序列.endswith(⼦串, 开始位置下标, 结束位置下标)
isalpha()
:判断字符串是否⾄少有⼀个字符并且所有字符都是字⺟
isdigit()
:判断字符串是否只包含数字
isalnum()
:判断字符串是否⾄少有⼀个字符并且所有字符都是字⺟或数字
isalnum()
:如果字符串⾄少有⼀个字符并且所有字符都是字⺟或数字
致谢
本文编写时参考了黑马程序员中相关的资料,在此特别感谢,如有侵犯,请联系我。