Python基础3切片,字符串的方法,for 循环

切片

切片:截取序列(字符串,列表,元组等)中某一段字符,并不改变原数据和数据类型。结构:[起始位置:终止位置:步长] 但不包括终止位置。所谓:顾头不顾尾。

索引:序列中每个元素都是有编号的,都是从0开始编号的。使用负数索引时,Python会从右边开始数,第一个元素为-1. 注意:用索引,在列表里是什么类型取出来的就是什么数据类型。而切片不一样,切出来的都是列表。

范例:

list=[1,2,"wo"]
print(list[1],type(list[1]))
print(list[2],type(list[2]))
print(list[1:2],type(list[1:2]))
print(list)

结果:

2 <class 'int'>

wo <class 'str'>

[2] <class 'list'>

[1, 2, 'wo']

倒取值(即取负值)切片:起始位置和步长共同决定了切取的方向,如果这两个切取方向不一致,会导致出现空值.

例子

word = "我是中国你好世界"

print(word[-1:-5:-1])  # 注意:步长为负的,起始位置从右往左,所以应该从右向左切片

# 结果  界世好你

print(word[1:5:1])  # 注意:步长正的,起始位置从左往右,所以应该从左向右切片
# 结果  是中国你

print(word[-1:5:1])  # 注意:步长正的,起始位置从右往左,相矛盾所以为空
# 结果空

字符串方法

字符串是不可变类型,就是说改变一个字符串的元素需要新建一个新的字符串,注意注意!!!这句话并不意味着,字符串没有方法,而是任何方法都不会改变原字符串,要得到使用方法的的结果只能另命名变量。它不像列表,使用方法(切片除外)会改变原列表。Python 里面没有字符这个类型,而是用长度为 1 的字符串来表示这个概念

范例:

print("list1",list1)
print("new_list",new_list) #原字符串就不会变

结果:

list1 nihaokdjl
new_list niHaokdjl

范例2:

list=[1,2,3,4]
list.append(6666)
print("list",list)     #列表就会变

结果:

list [1, 2, 3, 4, 6666]

如何改变一个字符串?

注意!注意!字符串是不可以改变的,但是你可以通过拼接,来“改变字符串”。

a="您好,日本"
print(a,id(a))
a=a[:3]+"中国"
print(a,id(a))

结果:

您好,日本 2207187472184
您好,中国 2207188312992         #还是没有改变原来的字符串,仅仅是定义了一个和他相同的变量

1.capitalize 字符串首字母大写,其余的全小写。

s="abdeH,ehrDFG"
print(s.capitalize())

结果:

Abdeh,ehrdfg

2.title字符串 以特殊符号或者空格隔开,隔开的每一部分的首字母大写,如果不隔开那就是一个字符串的首字母大写。其余的全是小写,与capitalize的不同是,capitalize特殊符号或者空格隔开的首字母不大写。

列子:

s="abdeH,ehrerG"
b="sjhiHjkh"
print("s",s.t)itle())
print("b",b.title()

结果:

s Abdeh,Ehrerg
b Sjhihjkh

3. upper() 方法将字符串中的小写字母转为大写字母。这里不举例子了

4. lower() 方法将字符串中的大写字母转为小写字母。这里不举例子了

5.count(“某元素”,索引开始,索引结束)字符串中某元素出现的个数,索引可以不写。

s="abdeH,ehrerG"
print("s",s.count("e"))

结果:

s 3

6.startswith 判断是否以..开头

endswith 判断是否以..结尾

例子:

s="abdeH,ehrerG"
print("s",s.startswith("abde"))
print("s",s.endswith("Gr"))
print("s",s.endswith("rG"))

结果:

s True
s False   #
s True   #注意这个和上个的不同

7.find 寻找某个元素的索引值 str.find(str, beg=0, end=len(string))。如果找不到显示-1.

index 寻找某个元素的索引值 str.find(str, beg=0, end=len(string))。如果找不到显示会报错.

注意这两个函数:如果字符串中有多个相同的元素,只会得到最左边的索引。
s="abdeH,ehrerG"
print("s",s.find ("e"))
print("s",s.index ("e"))
print("s",s.index("tt"))

结果:

s 3
Traceback (most recent call last):
s 3
  File "C:/Users/PycharmProjects/untitled/day1/联系.py", line 463, in <module>
    print("s",s.index("tt"))
ValueError: substring not found

8.strip() 方法用于移除字符串头尾指定的字符(默认为默认删除空白符(包括'\n', '\r', '\t', ' ')),可传入一个参数,指定要去除的首尾。需要注意的是:传入的是一组字符串是编译器去除两端所有相应的字符,这个相应的字符是什么意思?这是关键看例子:

heString = 'saaaay yes no yaaaass'
print(theString.strip("say"))

得到的答案:

 yes no 

您发现了什么?是不是只要前后两端含有"a","s","y",就会从两端向中间开始删除,直到遇到不是这三个字符停止。并不是把"say"当做整体去删除。

 rstrip() 删除 string 字符串右边(right)的指定字符(默认为空格).方法同strip,

 lstrip() 删除 string 字符串左边(left)的指定字符(默认为空格).方法同strip,

列子:

s="aabdeH,ehrerG"
print("s",s.strip ("a",))
print("s",s.strip ("G",))

结果:

s bdeH,ehrerG
s aabdeH,ehrer

8.5 list()。将字符串按照字符分割成列表

a = 'wupeiqi'
l = list(a)
print(l)

结果:

['w', 'u', 'p', 'e', 'i', 'q', 'i']

9.str.split(str="", num=string.count(str)).将字符串按照分隔符分割成列表

  • str -- 分隔符,默认为所有的空字符,包括空格、换行(\n)、制表符(\t)等。
  • num -- 分割次数。

例子:

s="aabdeH,ehrerG"
print("s",s.split (",",1))

结果:

s ['aabdeH', 'ehrerG']

10. replace() 方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。如果不指定第三个,则全部替换。

str.replace(old, new[, max])
例子:
s="我爱中国,中国中国"
print("s",s.replace ("中国","我国",1))

结果:

 我爱我国,中国中国

10. str.isdigit() 判断字符串是否全部由数字组成。

11.str.isalnum 判断字符串是否含有数字或字母。

字符串的格式化

format_map

利用字典的映射关系

a = {
    "k":"中国",
    "l":"你好"
}
str = "{l},我爱{k}".format_map(a)
print(str)

结果:你好,我爱中国
profession = { 'name':['Barry', 'Bruce'], 
               'profession':['Engineer', 'Doctor'], 
               'age':[30, 31] } 
                       
# Use of format_map() function  
print('{name[0]} is an {profession[0]} and he'
      ' is {age[0]} years old.'.format_map(profession)) 
        
print('{name[1]} is an {profession[1]} and he'
      ' is {age[1]} years old.'.format_map(profession)) 

#结果:
Barry is an Engineer and he is 30 years old.
Bruce is an Doctor and he is 31 years old.

f

a = "中国"
str = f"你好,我爱{a}"
print(str)

#结果:你好,我爱中国

format

format是我们比较常用的一个字符串格式化的方法

简单的方法就不说了,说一下我在项目中遇到的format的用法,带有":"的

数字格式的定义以 ':' 号开始。碰到了': '字符就知道要定义一个数字的显示格式了。格式的定义顺序为

1. 对齐方式(>右对齐、<左对齐、^居中)

print('{:>10}'.format(933)) #10代表的为10位,不够10位的用空格表示,>代表右对齐
#结果
933

2. 保留小数

print('{:.2f}'.format(99.887))  # 2f指的是保留2位小数

#结果
99.89

3.将小数转换成百分比

print('{:.2%}'.format(0.333))  # 2%指的是保留小数点后两位

#结果
33.30%

4.将10进制转换成其他进制

'{0:x}'.format(20)                转换成十六进制

'{0:o}'.format(20)                转换成八进制    

      进制转换的时候用{0:进制}

5.指定整数的位数,不足在前边用0补齐

import random

verify_code = '{0:06d}'.format(random.randint(0, 999999)) #06指定出现的数字是6位的,不够6位的用0补在前面凑够6位,:前边的0可以省略
print(">>>", verify_code)

#结果
053865

for 循环

不用for循环如何把一段字符串中的每个元素打印出来?

seer="我爱中国我是中国人"
count=0
while count<len(seer):
    print(seer[count])
    count+=1

结果:

我
爱
中
国
我
是
中
国
人