Python之路(第三篇):Python基本数据类型字符串(二)

一、基本数据类型
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
Nicholas

 
Nicholas
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

  

 

字符串

count:(python中的count()函数,从字面上可以知道,他具有统计功能)

Python count() 方法用于统计字符串里某个字符出现的次数。可选参数为在字符串搜索的开始与结束位置。

语法

count()方法语法:

str.count(sub, start= 0,end=len(string))

参数

  • sub -- 搜索的子字符串
  • start -- 字符串开始搜索的位置。默认为第一个字符,第一个字符索引值为0。
  • end -- 字符串中结束搜索的位置。字符中第一个字符的索引为 0。默认为字符串的最后一个位置。

返回值

该方法返回子字符串在字符串中出现的次数。

 例子

1 strings="How do you do"
2 
3 print(strings.count("o"))

 

其中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

  

posted on 2018-03-12 10:01  Nicholas--  阅读(583)  评论(0编辑  收藏  举报

导航