python字符串用法

一,数据类型的转换

1常用的数据类型有int,str,bool三种;

int是整型:一般的操作是查找数据的二进制长度bit_length()
一般数据有:
1)二进制:逢二进一
2)十进制,(0-9)逢十进一
3)八进制,(0-7)蜂八进一
4)十六进制逢 (0-F)十六进一
例:
a=10 
print(a.bit_length())#就能得到a这个变量的值的二进制长度

二,数据类型的转换

结论1:把x转换成y类型 y(x)
例子:print(bool(-1))#将布尔值转变成数据类型
print(int(a))#将a转变成数据类型
print(str(a)#将a转变成字符类型 
结论2:空的东西是False, 非空的东西是True,
false: False: 0,'',[],{},set(),tuple(),None(真空)
print(bool({}) #false

三,索引切片

1,在python和其他开发语言中我们的索引都是从零开始算的

 反向 -7 -6-5 -4 -3-2 -1
 正向  0  1 2  3  4 5  6
 s = "文 能 提 笔 安 天 下"
 print(s[3])
 print(s[7]) # index out of range 超过了索引的范围
 print(s[-8]) # 反向索引 - 反向
切片 从字符串中获取新字符串.例子:
s = "银王喜欢和金王一起讨论污王"
s1 = s[5]+s[6]+s[7]+s[8]
print(s1)
s[start: end] 从start切到end。 但是不包含end. 顾头不顾尾
s2 = s[5:9] #  从5-9 没有9
print(s2)
print(s[3:7]) # 欢和金王
print(s[5:]) # 从5开始, 到末尾
print(s[:5]) # 从头开始到5结束
print(s[:]) # 从头到尾
print(s[5:3]) # 默认的方向是从左到右.
s[start: end: step] step如果是正数 从左到右。 如果是负数就是从右到左
s = "金毛狮王谢逊紫衫龙王黛绮丝"
print(s[3:1:-1]) # 可以从右往左切片
print(s[1:8:3])  #从左往右切且各三个取一个值
print(s[::-1])

总结:

s[start: end: step]
start:  起始位置
end:  结束为止。取不到
step:  步长。 每隔xx个取1个。 默认是1 如果step是-1 从右往左取值

四,字符串操作

1 upper() 全部转化成大写字母,loswer全部转换成小写,capitalize()首字母大写,title()每个单词首字母大写,swapcase()大写变小写小写变大写
2 strip() 去掉左右两段的空白(空格,\n, \t)
3 replace(old, new) 字符串替换
4 split() 切割. 得到的结果是一个列表.
5 startswith() 判断是否以xxx开头,endswith()判断以什么结尾
6 find() 查找。如果找到了。 返回索引。如果找不到返回-1
7 len() 内置函数,求字符串长度
8 count()计数计算字符或数字出现的次数
9 isdigit(),判断是否是数字

例子

2.有字符串s = "123a4b5c"
1)通过对s切⽚形成新的字符串s1,s1 = "123"
    s="123a4b5c"
    s1=s[0:3]
    print(s1)
2)通过对s切⽚形成新的字符串s2,s2 = "a4b"
    s="123a4b5c"
    s2=input(s[3:6])
    print(s2)
3)通过对s切⽚形成新的字符串s3,s3 = "1345"
    s="123a4b5c"
    s3=s[0:8:2]
    print(s3)
4)通过对s切⽚形成字符串s4,s4 = "2ab"
    s="123a4b5c"
    s4=s[1:7:2]
    print(s4)
5)通过对s切⽚形成字符串s5,s5 = "c"
    s="123a4b5c"
    s5=s[-1]
    print(s5)
6)通过对s切⽚形成字符串s6,s6 = "ba2"
    s="123a4b5c"
    s6=s[-3:-8:-2]
    print(s6)
3.使⽤while和for循环分别打印字符串s="asdfer"中每个元素。
#(while循环)
s="asdfer"
index=0
while index<len(s):
    print(s[index])
    index+=1
#(for循环)
    # s="asdfer"
    # for i in s:
    #     print(i)
4.使⽤for循环对s="asdfer"进⾏循环,但是每次打印的内容都是"asdfer"。
 s="asdfer"
    for i in s:
        print(i,s)
5.使⽤for循环对s="abcdefg"进⾏循环,每次打印的内容是每个字符加上sb,
 s="abcdefg"
    for i in s:
        print(i +"sb")
作业及默写
1.有变量name = "aleX leNb" 完成如下操作:
1)移除 name 变量对应的值两边的空格,并输出处理结果
    name = "alex leNb"
    print(name.strip())
2)移除name变量左边的"al"并输出处理结果
    name = "alex leNb"
    print(name.strip("al"))
3)移除name变量右⾯的"Nb",并输出处理结果
    name= "alex leNb"
    print(name.strip("Nb"))
4)移除name变量开头的a"与最后的"b",并输出处理结果
    name="alex leNb"
    print(name.strip("a"+"b"))
5)判断 name 变量是否以 "al" 开头,并输出结果
    name="alex leNb"
    n=name.startswith("al")
    if n == True:
        print("name is al start")
    else:
        print("is not al start")
6)判断name变量是否以"Nb"结尾,并输出结果
    name = "alex leNb"
    n=name.endswith("Nb")
    if n== True:
        print("是以Nb结尾")
    else:
        print("不是以Nb结尾")
7)将 name 变量对应的值中的 所有的"l" 替换为 "p",并输出结果
    name = "alex leNb"
    print(name.replace("l","p"))
8)将name变量对应的值中的第⼀个"l"替换成"p",并输出结果
    name="alex leNb"
    n=name.replace("al","ap")
    print(n)
9)将 name 变量对应的值根据 所有的"l" 分割,并输出结果。
    name="alex leNb"
    print(name.split("l"))
10)将name变量对应的值根据第⼀个"l"分割,并输出结果。
    print(name.replace("al","ap").split("p"))
11)将 name 变量对应的值变⼤写,并输出结果
    name="alex leNb"
    print(name.upper())
12)将 name 变量对应的值变⼩写,并输出结果
    name="alex leNb"
    print(name.lower())
13)将name变量对应的值⾸字⺟"a"⼤写,并输出结果
    name="alex leNb"
    print(name.capitalize())
    print(name.title())
    print(name.swapcase())
大写变小写,小写变大写
    name="alex leNb"
    print(name.upper())
14)判断name变量对应的值字⺟"l"出现⼏次,并输出结果
    name="alex leNb"
    print(name.count("l"))
15)如果判断name变量对应的值前四位"l"出现⼏次,并输出结果
    name="alex leNb"
    i=name[0:4]
    print(i.count("l"))
16)从name变量对应的值中找到"N"对应的索引(如果找不到则报错),并输出结果
    name="alex leNb"
    print(name.index("N"))
17)从name变量对应的值中找到"N"对应的索引(如果找不到则返回-1)输出结果
    name="alex leNb"
    print(name.find("N"))
18)从name变量对应的值中找到"X le"对应的索引,并输出结果
    name="alex leNb"
    print(name.find("x le"))
19)请输出 name 变量对应的值的第 2 个字符?
    name="alex leNb"
    print(name.find("l"))
20)请输出 name 变量对应的值的前 3 个字符?
    name = "alex leNb"
    print(name.find("a"),name.find("l"),name.find("e"))
21)请输出 name 变量对应的值的后 2 个字符?
    name="alex leNb"
    print(name.find("N"),name.find("b"))
22)请输出 name 变量对应的值中 "e" 所在索引位置?
    name="alex leNb"
    print(name.find("e"))
例如:asb, bsb,csb,...gsb。
6.使⽤for循环对s="321"进入循环,打印的内容依次是:"倒计时3秒","倒计时
2秒","倒计时1秒","出发!"。
s="321"
for t in s:
    print("倒计时" + t + "s")
else:
    print("出发")
7,实现⼀个整数加法计算器(两个数相加):
如:content = input("请输⼊内容:") ⽤户输入:5+9或5+ 9或5 + 9,然后进
行分割再进⾏计算。
content=input("请输入内容")
n=content.split("+")
s=0
for i in n:
    s += int(i)
    print(s)
8,升级题:实现⼀个整数加法计算器(多个数相加):
如:content = input("请输⼊内容:") 用户户输入:5+9+6 +12+ 13,然后进行计算
content=input("请输入内容")
n=content.split("+")
s=0
for i in n:
    s += int(i)
    print(s)
分割再进⾏计算。
9,计算⽤户输⼊的内容中有⼏个整数(以个位数为单位)。
如:content = input("请输入内容:") # 如fhdal234slfh98769fjdla
content=input("请输入内容")
count=0
for b in content:
    if b.isdigit()==1:
        count=count+1
print(count)

五迭代

for 变量 in 可迭代对象:
循环体(break,continue)
else:

例子

写代码,完成下列需求:
用户可持续输出(用while循环),用户使用的情况:
输⼊A,则显示走大路回家,然后在让用户户进二步选择:
是选择公交车,还是步⾏?
选择公交车,显示10分钟到家,并退出整个程序。
选择步⾏,显示20分钟到家,并退出整个程序。
输⼊B,则显示⾛⼩路回家,并退出整个程序。
输⼊C,则显示绕道回家,然后在让用户进行步选择:
是选择游戏厅玩会,还是⽹吧?
选择游戏厅,则显示 ‘一个半⼩时到家,爸爸在家,拿棍等你。’并让其
重新输⼊A,B,C选项。
选择⽹吧,则显示‘两个⼩时到家,妈妈已做好了战斗准备。’并让其重
新输⼊A,B,C选项。
 while True:
        user=input("请输入一个字母A或B或C:")
        if user=="C":
            print("绕道回家")
            use1 = input("请问是游戏厅还是网吧玩会:")
            if use1 =="游戏厅":
                print("一个半小时到家,爸爸在家,拿棍等你。")
            elif use1 == "网吧":
                print("两个小时到家,妈妈已做好了战斗准备。")
        elif user=="A":
            print("走大路回家")
            use2=input("请问坐公交还是步行:")
            if use2 == "公交车" :
                print("10分钟到家")
                break
            elif use2 =="步行":
                print("20分钟到家")
                break
        else:
            print("走小路回家")
            break
写代码:计算 1 - 2 + 3 ... + 99 中除了88以外所有数的总和?
i=1
sumi=0
j=1
sumj=0
while i<99 and j<99:
    sumi=sumi+i
    j = i + 1
    i += 2
    if j==88:
        continue
    sumj = sumj + j
print(sumi-sumj)(升级题)判断⼀句话是否是回⽂. 回⽂: 正着念和反着念是⼀样的. 例如, 上海
⾃来⽔来⾃海上(升级题)
    while True:
        wen = input("请输入一句话:")
        if wen[0:] == wen[-1::-1] :
            print("这句话是回文")
        else:
            print("不是回文")
13. 输⼊一个字符串,要求判断在这个字符串中⼤写字⺟,小写字⺟,数字,


其它字符共出现了多少次,并输出出来


 content=input("请输入内容")
    count=0
    cont1=0
    cont2=0
    cont3=0
    for a in content:
        if a.isdigit()==1:
            count=count+1
    # print(count)
        elif a.islower()==1:
            cont1 += 1
    # print(count1)
        elif a.isupper()==1:
            cont2 +=1
    #print(cont2)
        else:
            cont3 +=1
    print("数字",count,"个")
    print("小写字母",cont1,"个")
    print("大写字母",cont2,"个")
    print("其他字符", cont3,"个")

14给出百家姓. 然后用户输入一个人的名字. 判断这个姓是否是百家姓中的姓氏

first_name=\
'''赵钱孙李,周吴郑王。
冯陈褚卫,蒋沈韩杨。
朱秦尤许,何吕施张。
孔曹严华,金魏陶姜。
戚谢邹喻,柏水窦章。
云苏潘葛,奚范彭郎。
鲁韦昌马,苗凤花方。
俞任袁柳,酆鲍史唐。
费廉岑薛,雷贺倪汤。
滕殷罗毕,郝邬安常。
乐于时傅,皮卞齐康。
伍余元卜,顾孟平黄。
和穆萧尹,姚邵湛汪。
祁毛禹狄,米贝明臧。
计伏成戴,谈宋茅庞。
熊纪舒屈,项祝董梁。
杜阮蓝闵,席季麻强。
贾路娄危,江童颜郭。
梅盛林刁,钟徐邱骆。
高夏蔡田,樊胡凌霍。
虞万支柯,昝管卢莫。
经房裘缪,干解应宗。
丁宣贲邓,郁单杭洪。
包诸左石,崔吉钮龚。
程嵇邢滑,裴陆荣翁。
荀羊於惠,甄曲家封。
芮羿储靳,汲邴糜松。
井段富巫,乌焦巴弓。
牧隗山谷,车侯宓蓬。
全郗班仰,秋仲伊宫。
宁仇栾暴,甘钭厉戎。
祖武符刘,景詹束龙。
叶幸司韶,郜黎蓟薄。
印宿白怀,蒲邰从鄂。
索咸籍赖,卓蔺屠蒙。
池乔阴鬱,胥能苍双。
闻莘党翟,谭贡劳逄。
姬申扶堵,冉宰郦雍。
卻璩桑桂,濮牛寿通。
边扈燕冀,郏浦尚农。
温别庄晏,柴瞿阎充。
慕连茹习,宦艾鱼容。
向古易慎,戈廖庾终。
暨居衡步,都耿满弘。
匡国文寇,广禄阙东。
欧殳沃利,蔚越夔隆。
师巩厍聂,晁勾敖融。
冷訾辛阚,那简饶空。
曾毋沙乜,养鞠须丰。
巢关蒯相,查后荆红。
游竺权逯,盖益桓公。
万俟司马,上官欧阳。
夏侯诸葛,闻人东方。
赫连皇甫,尉迟公羊。
澹台公冶,宗政濮阳。
淳于单于,太叔申屠。
公孙仲孙,轩辕令狐。
钟离宇文,长孙慕容。
鲜于闾丘,司徒司空。
丌官司寇,仉督子车。
颛孙端木,巫马公西。
漆雕乐正,壤驷公良。
拓跋夹谷,宰父谷梁。
晋楚闫法,汝鄢涂钦。
段干百里,东郭南门。
呼延归海,羊舌微生。
岳帅缑亢,况郈有琴。
梁丘左丘,东门西门。
商牟佘佴,伯赏南宫。
墨哈谯笪,年爱阳佟。
第五言福,百家姓终。'''
#for循环
name = input("请输入用户名") for i in first_name : if i == name[0] : break print(i,"在百家姓中") else: print("不在百家姓中")
#while循环
while True: name = input("请输入用户名") if name[0] in first_name : print("在百家姓中") continue else: print("不在百家姓中") 
六,格式化输出


制作趣味模板程序需求:等待⽤户输⼊名字、地点、爱好,根据⽤户的名
字和爱好进⾏任意现实 如:敬爱可亲的xxx,最喜欢在xxx地⽅⼲xxx


aihao="和蔼可亲的%s,最喜欢在%s,干%s" %("刘传盛","小树林","谈恋爱")
love="{}的演的电影,是{},{}很喜欢" .format("周星驰","幽默的","大家")
AV="{0},{1},{2},{3},都是{4},受广大{5}喜欢" .format("苍井空","泷泽萝拉","小泽玛丽牙","波多野结衣","日本明星","宅男")
print(AV)
print(love)
print(aihao)