六六是狗子

导航

15期day06 字符串与列表的常用操作

 

基本数据类型:

 1:int类型定义:age=int(10)

 名字(参数)

 类型转换:res=int('100010') 纯数字字符串转为int

 名字(参数)

 

字符串类型:

 定义:msg='hello'

类型转换:str可以把任意类型转成字符串

 1.:优先掌握:

 1、1:按索引值取(正向取+反向取),只能取

msg='hello world'

 正向取:print(msg[0])

 反向取;print(msg[-1])

只能取:msg[0]='H'(不能改)

1、2:切片:索引的拓展应用,熊一个大字符串中拷贝一个子字符串

 msg='hello world'

 顾头 不顾尾

 res=msg[0:5]

 步长:

 res=msg[0:5:2]# 0 2 4

 反向步长:

 res=msg[5:0:-1]

 res=msg[:] == res=msg[0:5]

 print(len(msg))#统计字符的个数

 

1.3移除字符串两侧的多余的符号strip:默认去除多余空格

 msg='***jdhhebf***'

 msg.strip()

print(msg.strip) or input().strip()

 1.4切分split:把一个字符按照某种分隔符进行切分,得到一个列表

#默认分隔符是空格

 info='egon:18:male'

 res=infp.split

 print(res)

 默认分隔符是空格

指定分隔次数(了解)

1.7循环

 for x in "hello 你好":

   print(x)

#2:需要掌握:

 

 1、strip,lstrip,rstrip

 2、lower,upper(改为小写或者大写)

 msg='AbbbCCCC'

 print(msg.lower())

#3、starswith.endswith(以什么开始,以什么结束)

4.format,格式化字符串:format的三种玩法

 print("my name is %s %s" % ("egon",18))

 

 print("my name is {} {}".format("egon",18))

print("my name is {x} {y}".format(y=18,x="egon"))

 

 print("my {1}name is {0} {0}{1}{1}".format("egon",18))

 

x='egon'

 y=18

 print(f"=====>{x}===>{y}")

 5:split,rsplit(r为改变从右往左切,将字符串切成字符串)

 6、join:把列表拼接成字符串(以某种分隔符)

l='egon','16','male'

 ':'.join(l) (用':'来拼接)

 7、replace(替换参数)

 msg='you can you up no can no bb'

 print(msg.replace('you','YOU')

 8.isdigit:判断字符串是否由纯数字组成

--------------------------------------------------------------------------------

 列表:在[]内用逗号分隔开多个类型的值#

  用途:按照位置存多个值

 l=[111,3.1,'abc',[]]

 

 list(传入的是任意能够被for循环遍历的类型)

:常用操作、内置方法:

 1、按照索引存取值:(正向+反向取):可以改也可以取

l=[111,222,333,444,555]

 l[5]=666#超出索引范围则报错,即不能为列表增加值

 2、切片(顾头不顾尾,步长)

 l=[111,222,333,444,555]

 res=l[0:3]

 print(res)

 print(l)

 3、长度len()

 4/成员运算in和not in

 l=[111,222,333,444,555]

 print(111 in l)

 print(111 not in l)

 5、追加:

 l.append(666)

 print(l)

5.1 往指定位置前插入值insert

l.insert(0,123123231231)

 print(l)

 

 6、删除

 del l[0] #通用删除

 print(l.remove('111')) #l专属删除方法之指定元素删除

print(l.pop) #默认删除索引-1的值、可以返回所删除的值

 res=l.pop(1)

 print(l)

 print(res)

7、循环

 l=[111,"aaa",222,333,444,555]

 for item in l:

     print(item)

需要了解的操作:

# 1.find,rfind,index,rindex,count

# 1.1 find:从指定范围内查找子字符串的起始索引,找得到则返回数字1,找不到则返回-1

>>> msg='tony say hello'

>>> msg.find('o',1,3) # 在索引为1和2(顾头不顾尾)的字符中查找字符o的索引

1  

# 1.2 index:同find,但在找不到时会报错

>>> msg.index('e',2,4) # 报错ValueError

# 1.3 rfind与rindex:略

# 1.4 count:统计字符串在大字符串中出现的次数

>>> msg = "hello everyone"

>>> msg.count('e') # 统计字符串e出现的次数

4

>>> msg.count('e',1,6) # 字符串e在索引1~5范围内出现的次数

1

 

# 2.center,ljust,rjust,zfill

>>> name='tony'

>>> name.center(30,'-') # 总宽度为30,字符串居中显示,不够用-填充

-------------tony-------------

>>> name.ljust(30,'*') # 总宽度为30,字符串左对齐显示,不够用*填充

tony**************************

>>> name.rjust(30,'*') # 总宽度为30,字符串右对齐显示,不够用*填充

**************************tony

>>> name.zfill(50) # 总宽度为50,字符串右对齐显示,不够用0填充

0000000000000000000000000000000000000000000000tony

 

# 3.expandtabs

>>> name = 'tony\thello' # \t表示制表符(tab键)

>>> name

tony hello

>>> name.expandtabs(1) # 修改\t制表符代表的空格数

tony hello

 

# 4.captalize,swapcase,title

# 4.1 captalize:首字母大写

>>> message = 'hello everyone nice to meet you!'

>>> message.capitalize()

Hello everyone nice to meet you!  

# 4.2 swapcase:大小写翻转

>>> message1 = 'Hi girl, I want make friends with you!'

>>> message1.swapcase()  

hI GIRL, i WANT MAKE FRIENDS WITH YOU!  

#4.3 title:每个单词的首字母大写

>>> msg = 'dear my friend i miss you very much'

>>> msg.title()

Dear My Friend I Miss You Very Much 

 

# 5.is数字系列

#在python3中

num1 = b'4' #bytes

num2 = u'4' #unicode,python3中无需加u就是unicode

num3 = '四' #中文数字

num4 = 'Ⅳ' #罗马数字

 

#isdigt:bytes,unicode

>>> num1.isdigit()

True

>>> num2.isdigit()

True

>>> num3.isdigit()

False

>>> num4.isdigit() 

False

 

#isdecimal:uncicode(bytes类型无isdecimal方法)

>>> num2.isdecimal() 

True

>>> num3.isdecimal() 

False

>>> num4.isdecimal() 

False

 

#isnumberic:unicode,中文数字,罗马数字(bytes类型无isnumberic方法)

>>> num2.isnumeric() 

True

>>> num3.isnumeric() 

True

>>> num4.isnumeric() 

True

 

# 三者不能判断浮点数

>>> num5 = '4.3'

>>> num5.isdigit()

False

>>> num5.isdecimal()

False

>>> num5.isnumeric()

False

 

'''

总结:

    最常用的是isdigit,可以判断bytes和unicode类型,这也是最常见的数字应用场景

    如果要判断中文数字或罗马数字,则需要用到isnumeric。

'''

 

# 6.is其他

>>> name = 'tony123'

>>> name.isalnum() #字符串中既可以包含数字也可以包含字母

True

>>> name.isalpha() #字符串中只包含字母

False

>>> name.isidentifier()

True

>>> name.islower() # 字符串是否是纯小写

True

>>> name.isupper() # 字符串是否是纯大写

False

>>> name.isspace() # 字符串是否全是空格

False

>>> name.istitle() # 字符串中的单词首字母是否都是大写

False

--------------------------------------------------------------------------------

 

 

 

--------------------------------------------------------------------------------

 

 

需要掌握的操作

l=[111,222,111,111]

print(l.count(111))

 

l = [10, -1, 3, 2, 11, 7]

l.sort(reverse=True)

print(l)

 

l = [10, -1, 3, 2, 11, 7]

l.clear()

print(l)

 

l=['a',1,'b']

l.reverse()

print(l)

 

l=[11,22,33]

l.extend([444,555,66])

print(l)

#

l.append([444,555,666])

print(l)

 

# l1=[11,22,33]

l1列表内存存储

索引0 值11的内存地址

索引1 值22内存地址

索引2 值33内存地址

 

l2=l1.copy() # 等同于l4=l1[:]

l2列表内存存储

索引0 值11的内存地址

索引1 值22内存地址

索引2 值33内存地址

l2[0]=4444

print(l2) # [4444, 22, 33]

print(l1) # [11, 22, 33]

 

l3=l1

l3[0]=4444

print(l3)

print(l1)

posted on 2020-06-08 20:22  小六媛儿  阅读(199)  评论(0编辑  收藏  举报