其他分享
首页 > 其他分享> > 字符串的其他内置方法和列表的内置方法

字符串的其他内置方法和列表的内置方法

作者:互联网

字符串的其他内置方法(非常重要)

这些内置是在我们写程序的时候会经常用到的,使用我们有必要全部记住,就算不能全部记住,我们也需要知道字符串有的内置函数。

1.移除字符串首尾的指定字符 我们可以选择移除的方向默认是两边全部,不填写指定字符就是移除空格。
str = '!!!!春游去动物园!!!'
print(str.strip('!'))  # 春游去动物园
print(str.lstrip('!'))  # 春游去动物园!!! 移除左边
print(str.rstrip('!'))  # !!!!春游去动物园 移除右边

2.大小写
str2 = 'aBcD'
print(str2.lower())  # abcd 将所有的英文字母变为小写
print(str2.upper())  # ABCD 将所有的英文字母变为大写
print(str2.islower())  # False 判断字符串中所有的英文字母是否是纯小写  返回值是布尔值
print(str2.isupper())  # False 判断字符串中所有的英文字母是否是纯大写  返回值是布尔值

3.判断字符串的开头或者结尾是否是指定的字符
str3 = 'hello world'
print(str3.startswith('h'))  # True
print(str3.startswith('hello'))  # True
print(str3.startswith('world'))  # False
print(str3.endswith('d'))  # True
print(str3.endswith('world'))  # True
print(str3.endswith('hello'))  # False

4.格式化输出
第一种:和占位符用法一样,但是使用{}占位
print('I am {},hobby is {}'.format('春游去动物园','玩'))

第二种:根据索引取值  可以反复使用
print('I am {0} {0} {1},hobby is {1} {0}'.format('春游去动物园','玩'))
I am 春游去动物园 春游去动物园 玩,hobby is 玩 春游去动物园

第三种:根据指名道姓的方式取值
print('I am {name} {hobby},hobby is {name}{hobby}'.format(name = '春游去动物园',hobby = '玩'))
I am 春游去动物园 玩,hobby is 春游去动物园玩

第四种:直接使用已经出现过的变量
name = '春游去动物园'
hobby = '玩'
print(f'I am {name} {hobby},hobby is {hobby} {name}')
I am 春游去动物园 玩,hobby is 玩 春游去动物园
千万不要忘了在要格式化输出的字符串前加f!!!!!!

5.拼接字符串
str5 = '少壮不努力'
str5_1 = '老来靠吉言'
print(str5 + str5_1)#少壮不努力老来靠吉言
print(str5 * 5)#少壮不努力少壮不努力少壮不努力少壮不努力少壮不努力
print('|'.join(str5))#少|壮|不|努|力
print('*'.join(['1', '2', '3', '4', '5']))#1*2*3*4*5
join的元素必须都是字符串才可以 否则报错

6.替换字符串中指定的字符
str6 = 'hello hello hello world hero hello'
替换全部
print(str6.replace('hello', '111'))  #111 111 111 world hero 111
替换指定的个数(从左往右)
print(str6.replace('hello', '111', 1))  #111 hello hello world hero hello

7.判断字符串中是否是纯数字
str7 = 'qwe123'
print(str7.isdigit())  # False
print('123'.isdigit())  # True
print('123.123'.isdigit())  # False

需要了解的操作

 1.查找指定字符对应的索引值
 s1 = 'jason justin kevin tony'
 print(s1.find('s'))  # 从左往右查找 查找一个就结束
 print(s1.find('k', 1, 9))  # -1 意思是没有 找不到
 print(s1.index('s'))
 print(s1.index('k', 1, 9))  # 找不到直接报错 不推荐使用

 2.文本位置改变
 name = 'tony'
 print(name.center(30, '-'))  # -------------tony-------------
 print(name.ljust(30, '*'))  # tony**************************
 print(name.rjust(30, '$'))  # $$$$$$$$$$$$$$$$$$$$$$$$$$tony
 print(name.zfill(50))  # zero 零  0000000000000000000000000000000000000000000000tony

 3.特殊符号:斜杠与一些英文字母的组合会产生特殊的含义
 print('ja\tson\nke\avin')
'''如果想取消它们的特殊含义 可以在字符串的前面加一个字母r'''
 print(r'ja\tson\nke\avin')

 4.capitalize,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

列表内置方法

1.类型转化
print(list('春游去动物园'))  # ['春', '游', '去', '动', '物', '园']
print(list({'name': '春游去动物园', 'password': 123}))  # ['name', 'password']
print(list((11, 22, 33, 44, 55)))  # [11, 22, 33, 44, 55]
print(list({1, 2, 3, 4, 5}))  # [1, 2, 3, 4, 5]

"""
    list可以转换支持for循环的数据类型
        可以被for循环的数据类型
            字符串 列表 字典 元组 集合
"""

2.常见操作
data = ['春', '游', '去', '动', '物', '园']

  1.索引取值
  print(data[0])  # 春

  2.切片操作
  print(data[1:3])  # ['游', '去']
  print(data[-1::-1])  # ['园', '物', '动', '去', '游', '春']

  3.间隔
  print(data[1:5:2])  # ['游', '动']

  4.统计列表中元素的个数
  print(len(data))  # 6

  5.成员运算 最小判断单位是元素不是元素里面的单个字符
  print('春' in data)  # True
  print('111' in data)  # False

  6.列表添加元素的方式
    1.尾部追加'单个'元素
    data.append('去')
    print(data)  # ['春', '游', '去', '动', '物', '园', '去']
    data.append(['游乐园'])
    print(data)  # ['春', '游', '去', '动', '物', '园', '去', ['游乐园']]

    2.指定位置插入'单个'元素
    data.insert(0, '我')
    print(data)  # ['我', '春', '游', '去', '动', '物', '园']
    data.insert(4, '去哪')
    print(data)  # ['我', '春', '游', '去', '去哪', '动', '物', '园']

    3.合并列表
    data.extend([11, 22, 33, 44, 55])
    print(data)  # ['春', '游', '去', '动', '物', '园', 11, 22, 33, 44, 55]
    '''extend其实可以看成是for循环+append'''
    data += [11,22,33,44] # 加号的效率不高
  
  7.删除
    1.通用的删除方式
    del data[0]
    print(data)#['游', '去', '动', '物', '园']
    
    2.指名道姓的直接删除某个元素
    data.remove('去')
    print(data)  # ['春', '游', '动', '物', '园']
    
    3.延迟删除
    data.pop()  # 默认是尾部弹出
    print(data)  # ['春', '游', '去', '动', '物']
    data.pop(1)
    print(data)  # ['春', '去', '动', '物', '园']
    data.pop(0)
    print(data)  # ['游', '去', '动', '物', '园']

  8.修改列表元素
  data[0] = '秋'
  print(data)  # ['秋', '游', '去', '动', '物', '园']

  9.排序
  data_number = [1, 5, 3, 6, 8, 0, 66]
  data_number.sort()  # 默认是升序
  print(data_number)  # [0, 1, 3, 5, 6, 8, 66]
  data_number.sort(reverse=True)  #降序
  print(data_number)  # [66, 8, 6, 5, 3, 1, 0]

  10.反转
  data.reverse()  #顺序颠倒,(前面的到后面去)
  
  11.比较运算
  s1 = [11, 22, 33]
  s2 = [1, 2, 3, 4, 5, 6, 7, 8]
  print(s1 > s2)  # True
  """列表在做比较的时候 其实比的是对应索引位置上的元素"""
  s1 = ['A', 'B', 'C']  # A>>>65
  s2 = ['a']  # a>>>97
  print(s1 > s2)  # False
  """如果比较的2个是字母,将会根据字母的ASCII码值来进行比较。"""
  
  12.统计列表中某个元素出现的次数
  l1 = [11, 22, 33, 44, 33, 22, 11, 22, 11, 22, 33, 22, 33, 44, 55, 44, 33]
  print(l1.count(11))  # 统计元素11出现的次数
  l1.clear()  # 清空列表

可变类型和不可变类型

    可变数据类型:列表list和字典dict;不可变数据类型:整型int、浮点型float、字符串型string和元组tuple。

  """
     可变类型与不可变类型
    可变类型     列表
        值改变 内存地址不变 修改的是本身
    不可变类型   字符串
        值改变 内存地址肯定遍 修改过程产生了新的值
如何查看变量的'内存地址'
id(变量名)
"""

队列和堆栈

Stack(栈):数据先进后出,类比放盘子,最先放的盘子最后拿出;最后放的盘子最先拿出

进栈:向一个栈插入新元素,它是把新元素放到栈顶元素的上面,变成新的栈顶元素;

出栈:从一个栈删除元素,它是把栈顶元素删除掉,使其相邻的元素成为新的栈顶元素。

####Queue(队列):数据先进先出 特点: (1)队列中的数据元素遵循“先进先出”(First In First Out)的原则,简称FIFO结构。

(2)在队尾添加元素,在队头删除元素。

标签:内置,name,方法,列表,春游,print,hobby,data,hello
来源: https://www.cnblogs.com/chunyouqudongwuyuan/p/15986473.html