一、基本数据类型
1、字符串 str
字符串方法介绍(二)
a --expandtabs( )
expandtabs( ) 把字符串中的 tab 符号('\t')转为空格
参数默认为8,注意字符串原有的空格也参与计算长度
test = "LinGou\tLinGengxin"
v1 = test.expandtabs( )
#这里是根据字符串的长度计算,expandtabs( )默认为8,执行方式如下
#"LinGou\tLinGengxin"
#LinGou是6个字符,此时遇到\t,expandtabs( )默认为8,要补全2个字符长度,即6+2=8,
#\t之后的字符不用处理
print(v1)v2 = test.expandtabs(6)
#同样的这里也是这样执行,参数为6,
# 字符串从左到右6个字符一组,LinGou是6个字符,忽略不作处理直接输出,此时遇到\t,
# 前面没有字符参与计算长度,此时需要\t直接输出6个空格
#\t之后的字符不用处理
print(v2)v3= test.expandtabs(7)
#参数为7,LinGou是6个字符,此时需要补全1个空格即可
#注意这里的空格是expandtabs()输出的,不是自带的
print(v3)test2 = "LinGou\t wang \twang"
v4 =test2.expandtabs(7)
#字符串原有的空格也参与计算长度
#参数为7,LinGou是6个字符,遇到第一个\t,此时需要补全1个空格即可
#继续计算,第一个\t输出一个空格,之后有一个字符串自带的空格,
#1个自带空格+wang(4个字符)+1个自带空格=6个长度,遇到\t,此时补全1个空格即可
#第二个\t之后的字符不用处理
print(v4)test3 = "123456\t789012345\t67890"
v5 =test3.expandtabs(6)
#参数为6,计算字符长度,123456长度为6,直接输出不做处理,
# 前面没有字符参与计算长度,此时需要\t直接输出6个空格
#继续计算,789012,长度为6,直接输出不做处理,
# 继续计算,345长度为3,遇到\t,此时需要补全3个空格
#第二个\t之后的字符不用处理
print(v5)
输出结果
LinGou LinGengxin
LinGou LinGengxin
LinGou LinGengxin
LinGou wang wang
123456 789012345 67890
举个例子
test = "name\temail\tpasswd\nnicholas\t123@qq.com\t123\nPony\t10001@qq.com\t12345\nTony\t10002@qq.com\t12345"
v6 = test.expandtabs(20)
print(v6)
输出结果
name email passwd
nicholas 123@qq.com 123
Pony 10001@qq.com 12345
Tony 10002@qq.com 12345
分析:这里的\n是换行符,这里可以通过\t、\n制作一个类似表格的结果。
b--isalpha()
isalpha( )判断字符串是否只包含字母、汉字,如包含数字、下划线则输出False
test = "nicholas"
v7 = test.isalpha()
print(v7)test2 ="nicholas1"
v8 = test2.isalpha()
print(v8)test3 ="尼古拉斯"
v9 = test3.isalpha()
print(v9)test4 ="nicholas尼古拉斯"
v10 = test4.isalpha()
print(v10)
输出结果
True
False
True
True
c--isdecimal()、isdigit()、isnumeric
isdecimal( )判断当前输入是否是数字
isdigit()判断当前输入是否是数字
test = "123"
v11 = test.isdecimal()
v12 = test.isdigit()
v13 = test.isnumeric()
print(v11, v12,v13)test1 = "②"
# 对于这种特殊符号的2,有的函数支持,有的不支持,所以出现了两种结果
v14 = test1.isdecimal()
v15 = test1.isdigit()
v16 = test.isnumeric()
print(v14, v15,v16)test2 = "IV" # 罗马数字,输入法特殊符号里输入,不能直接写英文字母I V
v17 = test2.isdecimal()
v18 = test2.isdigit()
v19 = test.isnumeric()
print(v17, v18,v19)test3 = "二" # 汉字
v20 = test2.isdecimal()
v21 = test2.isdigit()
v22 = test.isnumeric()
print(v20, v21,v22)
输出结果
True True True
False True True
False False True
False False True
分析:第三种罗马数字"IV",经测试,isdigit()、isdecimal()都输出False,有的博客写错了,写成isdigit()输出True,isdecimal()输出False。
digit:数字, decimal:十进制的,小数
numeric:数字的; 数值的
d--isidentifier()
判断字符串是否是合法的标识符,字符串仅包含中文字符合法,实际上这里类似判断变量名是否合法。
一般的变量命名以字母、数字、下划线,但数字不能开头,以上都会输出True
这里输出True的情况要加上仅包含中文字符,使用python内部函数名、标识符。
test = "123"
test1="_123"
test2="def"
test3="中国"
v23 = test.isidentifier()
v24 = test1.isidentifier()
v25 = test1.isidentifier()
v26 = test1.isidentifier()
print(v23,v24,v25,v26)
输出结果
False True True True
e--isprintable()
判断是否存在不可显示的字符
\n 换行 \t 制表符等在打印时无法显示出来
test = "123"
test1 = "123\n"
test2 = "123\t"
v27 = test.isprintable()
v28 = test1.isprintable()
v29 = test2.isprintable()
print(v27, v28,v29)
输出结果
True False False
f--isspace()
判断是否全部是空格,必须全部都是,空字符串也会输出False
下面的test3就是空字符串。
test = "123"
test1 = "12 3"
test2 = " "
test3 =""
v30 = test.isspace()
v31 = test1.isspace()
v32 = test2.isspace()
v33 = test3.isspace()
print(v30, v31,v32,v33)
输出
False False True False
g--istitle()、title()
istitle()判断是否是标题,即英文语句每个单词的首字母都是大写的
title()将英文语句转换为标题类型,即将每个单词的首字母都转为大写的
test = "Return True if all cased characters in S are uppercase and there is"
v1 = test.istitle()
print(v1)
v2 = test.title()
print(v2)
v3 = v2.istitle()
print(v3)
输出结果
False
Return True If All Cased Characters In S Are Uppercase And There Is
True
h--join()
将字符串中的每一个元素按照指定分隔符进行拼接
test = "大王叫我来巡山"
t1 = " "
t2 = "*"
v1 = t1.join(test)
v2 = t2.join(test)
print(v1)
print(v2)
输出结果
大 王 叫 我 来 巡 山
大*王*叫*我*来*巡*山
i--center()、ljust()、rjust()
center( ) 设置宽度,并将字符串内容居中,其他地方根据参数进行填充,默认为空白
ljust()设置宽度,并将字符串内容放在左边,其他地方根据参数进行填充,默认为空白
rjust()设置宽度,并将字符串内容放在右边,其他地方根据参数进行填充,默认为空白
test = "nicholas"
v1 = test.center(20,"*")
v2 = test.ljust(20,"*")
v3 = test.rjust(20,"*")
print(v1)
print(v2)
print(v3)
输出结果
******nicholas******
nicholas************
************nicholas
j--lower()、islower()、upper()、isupper()
lower()将英文字符转换为小写
islower()判断字符串是不是全部是小写
upper()将英文字符转换为大写
isupper()判断字符串是不是全部是大写
test = "Nicholas"
v1 = test.lower()
v2 = test.islower()
v3 = test.upper()
v4 = test.isupper()
print(v1)
print(v2)
print(v3)
print(v4)
输出结果
nicholas
False
NICHOLAS
False
k--strip()、lstrip()、rstrip()
strip(),移除指定的字符串,默认可以移除空格、\n 、\t,也可以指定要移除的字符
lstrip()移除原字符串左边的指定的字符串,默认可以移除空格、\n 、\t,也可以指定要移除的字符
rstrip()移除原字符串右边的指定的字符串,默认可以移除空格、\n 、\t,也可以指定要移除的字符
test = " Nicholas "
test2 = " \nNicholas\n"
test3 = "**Nicholas**"
v1 = test.strip()
v2 = test.lstrip()
v3 = test.rstrip()
v4 = test2.strip()
v5 = test2.lstrip()
v6 = test2.rstrip()
v7 = test3.strip("*")
v8 = test3.lstrip('*')
v9 = test3.rstrip('*')
print(v1)
print(v2)
print(v3)
print(v4)
print(v5)
print(v6)
print(v7)
print(v8)
print(v9)
输出结果
Nicholas
Nicholas Nicholas
Nicholas
NicholasNicholas
Nicholas
Nicholas**
**Nicholas
l--maketrans()、translate()
maketrans(),和translate()一起用
maketrans()做一种对应关系,translate()对其进行转换
str1 = "aeiou"
str2 = "12345"
test = "Nicholas"v1 = str.maketrans("aeiou","12345")
#做一种对应关系
v2 = test.translate(v1)
#进行转换,类似对明文密码进行加密
#根据对应关系,遇到i替换为3,遇到o替换为4,在没有对应关系的字符不变。
print(v2)
输出结果
N3ch4l1s
m--partition()、rpartition()、split()、rsplit()
partition()用来根据指定的分隔符将字符串进行分割。结果是分割为三部分,第一个为分隔符左边的子串,第二个为分隔符本身,第三个为分隔符右边的子串。
这个指定的字符是从左向右数的,如之后还有相同的字符也不再进行分割。
rpartition()功能与partition()相同,只是计算指定字符是从右向左数的。同样也是分为三部分,第一个为分隔符右边的子串,第二个为分隔符本身,第三个为分隔符左边边的子串。
同样的,之后还有相同的字符也不再进行分割。
split()指定分隔符对字符串进行切片,如果参数num 有指定值,则分隔 num个子字符串,但是指定的字符串不在出现在输出的结果中,这个是从左到右进行分割的
rsplit()与split()功能相同,只是这个是从右向左分割的。
str1 = "aeiouaeiou"
v1 = str1.partition("i")
v2 = str1.rpartition("i")
v3 = str1.split("i")
v4 = str1.rsplit("i")
print(v1)
print(v2)
print(v3)
print(v4)
输出结果
('ae', 'i', 'ouaeiou')
('aeiouae', 'i', 'ou')
['ae', 'ouae', 'ou']
['ae', 'ouae', 'ou']
再举个例子
str1 = "aeiouaeiouijk"v1 = str1.split("i",2)
v2 = str1.rsplit("i",2)
print(v1)
print(v2)
输出结果
['ae', 'ouae', 'ouijk']
['aeiouae', 'ou', 'jk']
分析:这里加了参数2,进行了2次分割。
n--splitlines()
根据换行符\n进行分隔,如果参数为False,不包含换行符,如果为True,则保留换行符。
str1 = "aeio\nuaeio\nuijk"
v1 = str1.splitlines()
v2 = str1.splitlines(False)
v3 = str1.splitlines(True)
print(v1)
print(v2)
print(v3)
输出结果
['aeio', 'uaeio', 'uijk']
['aeio', 'uaeio', 'uijk']
['aeio\n', 'uaeio\n', 'uijk']
o--swapcase()
用于对字符串的大小写字母进行转换。
大写字母转为小写,小写字母转为大写字母
str1 = "Nicholas"
str2 = "NicHolAs"
v1 = str1.swapcase()
v2 = str2.swapcase()
print(v1)
print(v2)
输出结果
nICHOLAS
nIChOLaS
p--replace()
字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。
str1 = "NicholasNicholasi"
v1 = str1.replace("i","niubi")
v2 = str1.replace("i","niubi",2)
print(v1)
print(v2)
输出结果
NniubicholasNniubicholasniubi
NniubicholasNniubicholasi
其中7个重要的方法要熟练掌握
join()
split()
find()
strip()
upper()
lower()
replace()
二、字符串的其他知识
1、索引,下标
获取字符串中的某一个字符
字符串的索引,下标,下标是从0开始的
str1 = "nicholas"
n i c h o l a s
0 1 2 3 4 5 6 7
str1 = "Nicholas"
v1 = str1[5]
v2 = str1[0:3]#注意这里是冒号,不是逗号,这里是前闭后开区间,即[0,3)
print(v1)
print(v2)
输出结果
l
Nic
2、len()
获取字符串长度,获取当前字符串中由几个字符组成
str1 = "Nicholas"
str2 ="尼古拉斯"
v1 = len(str1)
v2 = len(str2)
print(v1)
print(v2)
输出结果
8
4
3、for循环
for 变量名 in 字符串:
for循环可以遍历任何序列的项目,如一个列表或者一个字符串,简单的说就是for循环会自动对字符串的每个字符进行循环。等同于while循环中加上count = count + 1的效果。
str1 ="尼古拉斯真牛逼!"
i = 0
while i < len(str1):v = str1[i]print(v)i = i + 1
print("!!!!!")
输出结果
尼
古
拉
斯
真
牛
逼
!
!!!!!
用for循环也可以实现
str1 ="尼古拉斯真牛逼!"
for i in str1 :
#这里的i就会遍历str1中的所有字符,就是把字符串里的字符都跑一遍
#不用指定v=str1[i],可以直接print(i)print(i)
print("!!!!!")
输出结果
尼
古
拉
斯
真
牛
逼
!
!!!!!
4、切片
根据下标输出内容
str1 ="尼古拉斯真牛逼!"
v = str1[0:-1]
#这里的-1是指倒数第二个字符
print(v)
输出内容
尼古拉斯真牛逼
下标负数的数法下标负数的数法,下标可以为空表示取到头或尾。
尼 古 拉 斯 真 牛 逼 !
-8 -7 -6 -5 -4 -3 -2 -1
即从右向左开始,从-1开始数起。
举个例子
name = " Nicholas"v = name[-2:]print(v)
输出结果
1 as
5、字符串
一旦创建,不可修改,一旦修改或者拼接,都会造成重新生成字符串
Python中,数值类型(int和float)、字符串str、元组tuple都是不可变类型。而列表list、字典dict、集合set是可变类型。
6、range()
range()函数可创建一个整数列表,一般用在 for 循环中。
创建连续或不连续的数字。
Python2中range()直接创建内容,python3中只有for循环时,才一个一个创建
i = 0
for i in range(10):print(i)
输出结果
0
1
2
3
4
5
6
7
8
9
range()函数语法
range(start, stop[, step])
三个参数是开始,结束,步长,开始结束是前闭后开区间,第三个参数就是步长,默认为1,可以看做是跳过(步长-1)个整数输出一次。如果是负数,则是反向减去。
例子
i = 0
for i in range(1,20,3):print(i)
输出结果
1
4
7
10
13
16
19