首页 > 编程语言 >Python中级之数据类型的内置方法

Python中级之数据类型的内置方法

时间:2023-12-06 16:11:23浏览次数:43  
标签:输出 内置 name 示例 Python age 数据类型 字符串 print

常用方法概览

# 数字类型
int():类型强转
bin():转换二进制
hex():转换十六进制
oct():转换八进制
int(num,2/8/16) # 通过int()为其设置参数可进行机制转换

# 以下三种判断需在字符串类型下使用
.isdigit():判断是否均为整数数字[允许汉语数字]
.isdecimal():判断是否均为十进制数字[除数字外所有字符均不可以]
.isnumeric():对于数字的判断更宽泛,可汉语数字和整数数字同时出现
# 以上三种均不可判断浮点数
#字符串类型
.strip():去除空格
.split()/.rsplit():切分/从右向左切分,可以传切分次数的参数
.upper():全部大写
.lower():全部小写
.startswith():判断开头内容是否符合,返沪布尔值
.endswith():判断结尾内容是否符合,返沪布尔值
.join():拼接
.replace(old,new):替换
{}+.format():格式化输出
.find():查找,返回索引值
.index():同find,但找不到索引会报错
.count():计数
.center(长度,'填充字符'):居中对齐并按长度填充字符
.ljust(长度,'填充字符')/.rjust():左/右对齐并按长度填充字符
.captalize():首字母大写[仅第一个单词]
.swapcase():大小写反转
.title():所有单词首字母大写
.isidentifier():判断字符串内容是否都是合法字符
# 列表类型
.append():增加一个
.extend():增加多个元素
.insert([索引], ):根据索引增加
.del([索引]):删除索引对应的值
.pop():弹出最后一个元素,可以用变量接收
.remove(值):删除指定的值
.sort(reverse=True/False):默认升序排序,可以传入参数reverse进行降序排序,修改后无参数返回,直接修改原值
.sorted():与sort功能一致,但有返回值,可以使用变量接收
.reverse():颠倒顺序
# 字典类型
.update():增加键值对
.setdefault(key,value):寻找键并返回键对应值,没有键就新增键值对
.del():根据键值删除
.pop():弹出键值对,返回值
.clear():清空字典
.keys():取出键对
.values():取出值对
.items():取出键值对
.sorted():字典排序,根据ASKII码表排序
# 集合类型
.add():添加单个元素
.update():添加多个元素
.remove():删除指定元素
.discard():删除指定元素,找不到不会报错
.pop():随机删除元素,数字除外[因为按照hash排列]
| / .union():并集
- / .intersection():差集
^ / .symetric_difference():对称差集

【一】数字类型

【1】整数类型(int)

(1)基本运算

  • 实现整数的加法运算。

    • # int.__add__(other)
      num1 = 5
      num2 = 2
      result = num1.__add__(num2)
      print(result)    # 7    # 功能相当于 num1 + num2
      
  • 实现整数的减法运算。

    • # int.__sub__(other)
      num1 = 5
      num2 = 2
      result = num1.__sub__(num2)
      print(result)    # 3    # 功能相当于 num1 - num2
      
  • 实现整数的乘法运算。

    • # int.__mul__(other)
      num1 = 5
      num2 = 2
      result = num1.__mul__(num2)
      print(result)    # 10    # 功能相当于 num1 * num2
      
  • 实现整数的真除法运算

    • # int.__truediv__(other)
      num1 = 5
      num2 = 2
      result = num1.__truediv__(num2)
      print(result)  # 2.5    # 功能相当于 num1 / num2
      
  • 实现整数的整除法运算。

    • # int.__floordiv__(other)
      num1 = 5
      num2 = 2
      result = num1.__floordiv__(num2)
      print(result)  # 2    # 功能相当于 num1 // num2
      # 取整(//)数字相除,只取整数,舍弃小数点后的内容
      
  • 实现整数的取模运算。

    • # int.int.__mod__(other)
      num1 = 5
      num2 = 2
      result = num1.__mod__(num2)
      print(result)  # 1    # 功能相当于 num1 % num2
      # 取余(%)数字相除,只取余数
      
  • 实现整数的幂运算。

    • # int.__pow__(other, modulo=None)
      num1 = 5
      num2 = 2
      result = num1.__pow__(num2)
      print(result)  # 25    # 功能相当于 num1 ** num2
      # modulo = None 的含义相当于,(num1 ** num2) % modulo
      num1 = 5
      num2 = 2
      result = num1.__pow__(num2, 4)
      print(result)   # 1    # 5的2次方除以4,余1,故输出1
      
      

(2)类型强转

  • 只能将由纯整数构成的字符串直接转换成整型

    • 若包含其他任意非整数符号

    • 则会报错

      # 通过【int()】将变量强转成整形int
      # 变量名 = int(需要转换类型的变量)
      txt = '123'
      print(type(txt))   # <class 'str'>
      print(type(int(txt)))   # <class 'int'>
      # 需要注意,强转类型前的变量必须符合整形类型的条件
      txt2 = '123abc'
      print(int(txt2))   # ValueError: invalid literal for int() with base 10: '123abc'
      
    • 空值也不可以进行整型的转换

      print(int(''))   # ValueError: invalid literal for int() with base 10: ''
      

(3)进制转换

2、二进制转换(不常用)

  • int.bit_length()
    
    • 返回整数的二进制表示中最高位的位数,不包括符号和前导零。

    • num = 42
      bit_length = num.bit_length()
      print(bit_length)
      # 输出:6
      
  • int.to_bytes(length, byteorder, signed)
    
    • 将整数转换为字节数组。

    • 参数length指定生成的字节数组的长度,byteorder指定字节顺序,signed指定是否考虑整数的符号。

    • num = 42
      byte_array = num.to_bytes(2, byteorder='big', signed=False)
      print(byte_array)
      # 输出:b'\x00*'
      
  • int.from_bytes(bytes, byteorder, signed)
    
    • 将字节数组转换为整数。

    • 参数bytes是输入的字节数组,byteorder指定字节顺序,signed指定是否考虑整数的符号。

    • byte_array = b'\x00*'
      num = int.from_bytes(byte_array, byteorder='big', signed=False)
      print(num)
      # 输出:42
      

1、各进制转换(更常用一些)

  • 十进制转二进制
    • 二进制最小位数为8位,不够补‘0’
    • image-20231130192900137
  • 二进制转十进制
    • image-20231130193901601
[1]十进制转二进制:bin()
  • 将整数转换为二进制表示,返回一个字符串。

  • num = 42
    binary_representation = bin(num)
    print(binary_representation)
    # 输出:'0b101010'
    
[2]十进制转八进制:oct()
  • 将整数转换为八进制表示,返回一个字符串。

  • num = 42
    octal_representation = oct(num)
    print(octal_representation)
    # 输出:'0o52'
    
[3]十进制转十六进制:hex()
  • 将整数转换为十六进制表示,返回一个字符串。

  • 十六进制中(由0~9加上a,b,c,d,e,f表示)

  • 因为不可以由两位数表示,故用字母代替

    • a == 10 ; b == 11 ; c == 12 ; d ==13 ; e ==14 ;f ==15
    num = 42
    hexadecimal_representation = hex(num)
    print(hexadecimal_representation)
    # 输出:'0x2a'
    
[4]其它进制转十进制:int()
  • int() 函数支持将不同进制的字符串转换为十进制整数。主要的进制包括:

    • 二进制(以 '0b' 或 '0B' 开头)
    • 八进制(以 '0o' 或 '0O' 开头)
    • 十六进制(以 '0x' 或 '0X' 开头)
  • 你可以根据需要选择不同的进制进行转换。

  • binary_str = '0b101010'
    decimal_num = int(binary_str, 2)
    print(decimal_num)
    # 输出:42
    
    octal_str = '0o52'
    decimal_num = int(octal_str, 8)
    print(decimal_num)
    # 输出:42
    
    hexadecimal_str = '0x2a'
    decimal_num = int(hexadecimal_str, 16)
    print(decimal_num)
    # 输出:42
    
  • 在这些例子中,字符串的前缀表明了不同的进制

【2】浮点数类型(float)

(1)基本运算

# 加法  _add
result_add = 3.14 + 2.5
print(result_add)    # 5.640000000000001
# 减法  _subtract
result_subtract = 5.7 - 1.2
print(result_add)    # 4.5
# 乘法  _multiply
result_multiply = 2.0 * 3.5
print(result_subtract)    # 7.0
# 除法  _divide
result_divide = 8.0 / 4.0
print(result_divide)    # 2.0
# 取整  _number
rounded_number = round(3.14159)
print(rounded_number)    # 3

(2)类型强转

  • 将整数转换为浮点数

    • # 通过【float()】将变量强转成浮点型float
      # 变量名 = float(需要转换类型的变量)
      txt = 123
      print(type(txt))   # <class 'int'>
      print(type(float(txt)))   # <class 'float'>
      # 需要注意,强转类型前的变量必须符合浮点数类型的条件
      txt2 = '123a'
      print(float(txt2))
      # ValueError: could not convert string to float: '123a'
      

【3】判断数字类型

(1)数字类型说明

num1 = b'4'  # bytes
num2 = '4'   # unicode,Python 3 中不需要在字符串前加 'u'
num3 = '四'  # 中文数字
num4 = 'Ⅳ'   # 罗马数字

(2)判断数字类型(isdigit)

isdigit() 方法是 Python 字符串对象的方法之一,用于检查字符串是否只包含数字字符。这方法返回 True 如果字符串中所有的字符都是数字字符(0-9),否则返回 False

以下是 isdigit() 方法的基本用法:

pythonCopy codestring = "12345"
result = string.isdigit()
print(result)
# 输出: True

在这个例子中,isdigit() 方法返回 True,因为字符串 "12345" 中只包含数字字符。

isdecimal() 方法不同,isdigit() 允许字符串中包含 Unicode 中的数字字符(如罗马字符),但不允许字符串中包含其他非数字字符,如空格或小数点。

pythonCopy codeunicode_string = "一二三四五"
result = unicode_string.isdigit()
print(result)
# 输出: True

mixed_string = "123 45"
result = mixed_string.isdigit()
print(result)
# 输出: False

在这个例子中,isdigit() 对于包含汉字数字的字符串返回 True,但对于包含空格的字符串返回 False

(3)判断小数类型(isdecimal)

isdecimal() 方法是 Python 字符串对象的方法之一,用于检查字符串是否只包含十进制数字字符。这意味着字符串中的每个字符都必须是 0 到 9 的数字字符,而不能包含小数点、负号、空格或其他非数字字符。

以下是 isdecimal() 方法的基本用法:

pythonCopy codestring = "12345"
result = string.isdecimal()
print(result)
# 输出: True

在这个例子中,isdecimal() 方法返回 True,因为字符串 "12345" 中只包含十进制数字字符。

然而,需要注意的是,如果字符串包含除了数字字符以外的其他字符,isdecimal() 将返回 False。例如:

pythonCopy codestring = "123.45"
result = string.isdecimal()
print(result)
# 输出: False

在这个例子中,由于字符串包含小数点,isdecimal() 返回 False。如果你希望检查字符串中是否只包含数字字符,而不考虑小数点,可以使用 isdigit() 方法。

(4)判断数字类型(isnumeric)

isnumeric() 方法是 Python 字符串对象的方法之一,用于检查字符串是否只包含数字字符。类似于 isdigit() 方法,但 isnumeric() 还允许字符串中包含其他数字字符,如Unicode 中的数字字符(汉字数字等)。

以下是 isnumeric() 方法的基本用法:

pythonCopy codestring = "12345"
result = string.isnumeric()
print(result)
# 输出: True

在这个例子中,isnumeric() 方法返回 True,因为字符串 "12345" 中只包含数字字符。

isdigit() 方法相比,isnumeric() 更宽泛,它允许字符串中包含 Unicode 中的其他数字字符。例如:

pythonCopy codeunicode_string = "一二三四五"
result = unicode_string.isnumeric()
print(result)
# 输出: True

在这个例子中,isnumeric() 对于包含汉字数字的字符串返回 True

需要注意的是,isnumeric()isdigit() 的行为在处理不同类型的数字字符时可能有所不同,具体取决于字符串中包含的字符。在使用时,选择适合你需求的方法。

(5)无法判断浮点数

# 这三种方法无法判断浮点数
num5 = '4.3'
print(num5.isdigit())    # False
print(num5.isdecimal())  # False
print(num5.isnumeric())  # False

【二】字符串类型(str)

【0】字符串强转

  • 所有类型均可以强转至字符串,由引号引导

  • 列表类型、字典类型、元组类型强转至字符串后,所以引导符号将被视为字符

  • print(str([1, 2, 3])[0])  # [  list
    print(str({1, 2, 3})[0])  # {[  set
    print(str((1, 2, 3))[0])  # (   tuple
    print(str({'a': 1})[0])  # {   dict
    

【1】内置方法(优先)

(0)字符串拼接(+)

  • 字符串拼接是将多个字符串连接在一起形成一个新的字符串。

  • 可以使用 + 运算符来实现字符串拼接。

    • str1 = 'Hello,'
      str2 = 'World!'
      result_str = str1 + ' ' + str2
      print(result_str)
      # 输出: Hello, World!
      

(1)索引取值

[1]正索引取值

  • 字符串中的每个字符都有一个索引,正索引从左到右依次增加

    • text = 'Python'
      first_char = text[0]
      print(first_char)
      # 输出: P
      

[2]反索引取值

  • 反索引从右到左依次增加,最右边的字符索引为 -1。

    • text = 'Python'
      last_char = text[-1]
      print(last_char)
      # 输出: n
      

[3]只能取值,不能修改

  • str1 = 'hello python!'
    str1[0]='H' 
    '''
    Traceback (most recent call last):
      File "E:\PythonProjects\02用户交互.py", line 58, in <module>
        str1[0]='H' # 报错TypeError
    TypeError: 'str' object does not support item assignment
    '''
    

(2)切片(顾头不顾尾)

[1]切片顾头不顾尾

  • 切片用于获取字符串的一部分,可以指定起始索引和结束索引

    text = 'Python'
    substring = text[1:4]  # 从索引1到索引4(不包括4)
    print(substring)
    # 输出: yth
    

[2]步长

text = 'Python'
substring = text[1:4:2]  # 从索引1到索引4(不包括4) 步长为 2 ,所以 索引1为 y 和 索引3 为 h
print(substring)
# 输出: yh

[3]反向切片

text = 'Python'
substring = text[-1:-4:-2]
# 步长为负数时,负索引值可按照正常从左到右的思路使用
# 从索引-1到索引-4(不包括4) 步长为 2 ,所以 索引-1为 n 和 索引-3 为 h
print(substring)
# 输出: nh
print(text(::-1))
# nohtyP    # [start:stop:step]  [::步长]的含义是从头取到尾,若步长为负,则顺序颠倒

(3)计算长度(len())

  • len() 函数用于计算字符串的长度。

  • text = 'Hello, World!'
    length = len(text)
    print(length)
    # 输出: 13
    

(4)成员运算(in/not in)

  • innot in 用于检查一个字符串是否包含另一个字符串

[1]in

text = 'Hello, World!'
contains_hello = 'Hello' in text
print(contains_hello)
# 输出: True

[2]not in

contains_python = 'Python' in text
print(contains_python)
# 输出: False

(5)去除空格(.strip())

strip() 方法用于去除字符串首尾的空格。

[1] 默认 strip

  • 默认情况下,strip() 方法会去除字符串开头和结尾的所有空格。

  • text = '  Hello, World!  '
    stripped_text = text.strip()
    print(stripped_text)
    # Output: Hello, World!
    

[2] 左去除 lstrip

  • lstrip() 方法用于去除字符串开头的空格。

  • text = '  Hello, World!  '
    left_stripped_text = text.lstrip()
    print(left_stripped_text)
    # Output: Hello, World!  
    

[3] 右去除 rstrip

  • rstrip() 方法用于去除字符串结尾的空格。

  • text = '  Hello, World!  '
    right_stripped_text = text.rstrip()
    print(right_stripped_text)
    # Output:   Hello, World!
    

[4] 去除指定字符

  • 如果需要去除字符串开头和结尾的指定字符,可以传入一个字符串参数给 strip() 方法。

  • text = '<<Hello, World!>>'
    stripped_text = text.strip('<>')
    print(stripped_text)
    # Output: Hello, World!
    # 传入的字符串参数不限制为只有一个
    text = '<@#$%^&*<!Hello, World!>>><!@#$%^&*'
    print(text.strip('><!@#$%^&*'))
    # Hello, World
    # 需要注意,只有在头和尾没有接触到非规定外的字符时可以去除特殊符号
    text = 'aHello, Worlda!aaaabbbccc'
    print(text.strip('abc'))
    # Hello, Worlda!
    
  • 总结:

    s.strip(chars)使用规则:

    首先遍历chars中的首个字符,看看在S中是否处于首尾位置,如果是就去掉。把去掉后的新字符串设置为s,继续循环,从chars中的首个字符开始。如果不在,直接从chars第二个字符开始。一直循环到,s中首尾字符都不在chars中,则循环终止。

    Python中strip函数几种用法_strip在python中的用法-CSDN博客

  • 这些方法在处理用户输入、文件读取等场景中经常用到,可以有效地清理字符串的格式

(6)切分(split/rsplit)

  • split() 方法用于将字符串切分成多个子字符串,并返回一个包含切分后子字符串的列表。
  • .rsplit()方法便是反向,从右向左去切分对象

[1] 默认切分符

  • 如果不指定切分符,则默认使用空白作为切分符。空白可以是空格,可以是换行

  • text = 'Hello, World!'
    split_result = text.split()
    print(split_result)
    # Output: ['Hello,', 'World!']
    text1 = """
    hello
    world
    """
    print(text1.split())   # ['hello', 'world']
    

[2] 指定分隔符

  • 可以通过传递一个分隔符参数给 split() 方法来指定切分符。

  • text = 'apple,orange,banana'
    split_result = text.split(',')
    print(split_result)
    # Output: ['apple', 'orange', 'banana']
    
  • 在处理 CSV 格式的数据、日志文件等场景中,split() 方法非常实用,可以将字符串按照指定的分隔符拆分成各个字段。

[3]指定切分次数

  • 可以为.split()函数指定一个切分次数
  • str.split('切分字符',指定次数)
site = 'D:/A/B/C/D.TXT'
print(site.split('/'))
# ['D:', 'A', 'B', 'C', 'D.TXT']
# 切分成有5个元素的list
print(site.split('/', 1))
# 切分成只有2个元素的list

# 扩展
# 如果想要提取盘符最后的文件名
# 就可以使用.rsplit('/',1)
# 反向,从右向左取最后一个元素
print(site.rsplit('/',1))
# ['D:/A/B/C', 'D.TXT']
# 切分成由路径+文件名两个元素的list

(7)遍历字符串(for循环)

  • 使用 for 循环可以遍历字符串中的每个字符

  • text = 'Python'
    for char in text:
        print(char)
    # 输出:
    # P
    # y
    # t
    # h
    # o
    # n
    

(8)字符串重复(*)

  • 使用 * 运算符可以实现字符串的重复

  • original_str = 'ABC'
    repeated_str = original_str * 3
    print(repeated_str)
    # 输出: ABCABCABC
    

(9)大小写转换(.upper() / .lower())

  • 大小写转换,在验证码的场景下用的较多,平时常见的验证码都是随意大小写均可

[1]小写转大写(upper())

text = 'hello'
uppercase_text = text.upper()
print(uppercase_text)
# 输出: HELLO

[2]大写转小写(lower())

text = 'WORLD'
lowercase_text = text.lower()
print(lowercase_text)
# 输出: world

[3]举例

show_user = 'K2nF'
print(f"这是您需要输入的验证码:{show_user}")
input_user = input("请输入你看到的验证码,不区分大小写:>>>")

if show_user.upper() == input_user.upper():
# if show_user.lower() == input_user.lower():
    print("验证通过")
else:
    print("验证失败")

(10)首尾字符判断(.startswith() / .endswith())

[1]判断字符开头(startswith())

  • startswith()判断字符串是否以括号内指定的字符开头,结果为布尔值True或False

  • text = 'Python is fun'
    result = text.startswith('Python')
    print(result)
    # 输出: True
    

[2]判断字符结尾(endswith())

  • endswith()判断字符串是否以括号内指定的字符结尾,结果为布尔值True或False

  • text = 'Python is fun'
    result = text.endswith('fun')
    print(result)
    # 输出: True
    

(11)格式化输出( % / .format / f'{}' )

  • 之前讲到过 print() 函数的用法,这只是最简单最初级的形式,print() 还有很多高级的玩法,比如格式化输出。

[1] % 输出

  • 使用 % 运算符进行格式化输出,可以在字符串中插入占位符,然后通过 % 运算符传入相应的值。
# 格式化输出语法一 : %
name = "Lea4ning"
age = 18
height = 180.0

# 使用 %s 占位符,输出字符串
print("My name is %s." % name)  
# My name is Lea4ning.

# 使用 %d 占位符,输出整数
print("My age is %d." % age)  
# My age is 18.

# 使用 %f 占位符,输出浮点数,默认保留六位小数
print("My height is %f." % height)  
# My height is 180.000000.

# 使用 %.2f 占位符,保留两位小数
print("My height is %.2f." % height)  
# My height is 180.00.

# 使用 %x 占位符,输出十六进制整数
number = 255
print("Number in hex: %x." % number)  
# Number in hex: ff.

# 两个以上的占位符格式化输出
print("My name is %s; My age is %d" % (name, age)) 
# My name is Lea4ning; My age is 18
  • 在上例中,%s%d 是占位符,分别表示字符串和整数,而 (name, age) 是传入这两个占位符的实际值。
  • 占位符类型
    • %s:字符串
    • %d:整数
    • %f:浮点数
    • %x:十六进制整数

[2] formate 输出

  • 使用 format 方法进行格式化输出,通过花括号 {} 表示占位符,然后调用 format 方法传入实际值

  • name = "Lea4ning"
    age = 18
    # 格式化输出语法三 : formate
    print("My name is {}; My age is {}".format(name, age))
    # My name is Lea4ning; My age is 18
    # 可以通过约束索引值来取值   # 可以重复使用
    print("My name is {0}; My age is {1};{0},{1}".format(name, age))
    # 可以通过约束变量名取值   # 可以重复使用
    print("My name is {name}; My age is {age};{name},{age}".format(name, age))
    
  • 在这个例子中,{} 是占位符,它会按顺序依次填充传入 format 方法的值

[3] f + {} 输出

  • 使用 f-string(f + {})进行格式化输出,通过在字符串前加上 fF 前缀,然后在字符串中使用 {} 表示占位符,并在 {} 中直接引用变量。

  • name = "Lea4ning"
    age = 18
    # 格式化输出语法二 : f + {}
    print(f"My name is {name}; My age is {age}")
    # My name is Lea4ning; My age is 18
    

(12)拼接(.join)

  • 从可迭代对象中取出多个字符串,然后按照指定的分隔符进行拼接,拼接的结果为字符串
res_1 = '%'.join('hello')  # 从字符串'hello'中取出多个字符串,然后按照%作为分隔符号进行拼接
print(res_1)  # h%e%l%l%o

# 列表更加适用于join函数,可以按照元素进行添加间隔
res_2 = '|'.join(['Lea4ning', '18', 'code'])  # 从列表中取出多个字符串,然后按照*作为分隔符号进行拼接
print(res_2)  # Lea4ning|18|code

(13)替换(.replace())

  • 用新的字符替换字符串中旧的字符
res_1 = 'my name is Lea4ning, my age is 18!'  # 将Lea4ning的年龄由18岁改成99岁
res_1 = res_1.replace('18', '99')  # 语法:replace('旧内容', '新内容')
print(res_1)  # my name is Lea4ning, my age is 99!

# 可以指定修改的个数
res_2 = 'my name is Lea4ning, my age is 18!'
res_2 = res_2.replace('my', 'MY', 1)  # 只把一个my改为MY
print(res_2)  # MY name is Lea4ning, my age is 18!
  • 通过replace函数交换变量的值
m = 10
n = 20
res = str(m) + str(n)
print(res, type(res))   # 1020 <class 'str'># 将m和n的值转为字符串后拼接 
m = res.replace(str(m), '')   # 将res中str(m)的值,也就是'10',替换为空,res的值就只剩'20'
n = res.replace(str(n), '')   # 将res中str(n)的值,也就是'20',替换为空,res的值就只剩'10'
print(m, n)   # 20 10 <class 'str'> <class 'str'>

(14)判断类型(.isdigit())

  • 判断字符串是否是纯数字组成,返回结果为True或False

  • str8 = '5201314'
    res_1 = str8.isdigit()
    print(res_1)  # True
    
    str8 = '123g123'
    res_2 = str8.isdigit()
    print(res_2)  # False
    

【2】内置方法(熟悉)

(1)查找

[1]find

  • 从指定范围内查找子字符串的起始索引,找得到则返回索引值,找不到则返回-1

  • msg = 'tony say hello'
    
    # 在索引为1和2(顾头不顾尾)的字符中查找字符o的索引
    res = msg.find('o', 1, 3)
    print(res) # 1
    

[2]rfind

msg = 'tony say hello'

# 在整个字符串中查找字符o的最右边的索引
res = msg.rfind('o')
print(res) # 13

[3]index

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

  • msg = 'tony say hello'
    
    # 在整个字符串中查找字符o的最左边的索引
    res = msg.index('o')
    print(res) # 1
    print(msg.index('z',1,len(msg)+1))
    # ValueError: substring not found
    

[4]rindex

msg = 'tony say hello'

# 在整个字符串中查找字符o的最右边的索引
res = msg.rindex('o')
print(res) # 13

[5]count

  • 统计字符串在字符串中出现的次数
msg = 'tony say hello'

# 统计字符串o在字符串中出现的次数
res = msg.count('o')
print(res) # 2

(2)填充

[1]center

msg = 'tony'

# 用字符o将字符串居中,总长度为10,剩余的位置用-填充
res = msg.center(10, '-')
print(res) # --tony---

[2]ljust

msg = 'tony'

# 用字符o将字符串向左对齐,总长度为10,剩余的位置用-填充
res = msg.ljust(10, '-')
print(res) # tony------

[3]rjust

msg = 'tony'

# 用字符o将字符串向右对齐,总长度为10,剩余的位置用-填充
res = msg.rjust(10, '-')
print(res) # ------tony

[4]zfill

msg = 'Dream'

# 用字符0将字符串向右对齐,总长度为10,剩余的位置用0填充
res = msg.zfill(10)
print(res) # 000000Dream

(3)制表符

  • expandtabs
name = 'Lea4ning\thello'  # \t表示制表符(tab键)
print(name)  # Lea4ning	   hello 默认四个字符

location = "China\tFirst"
expanded_name = location.expandtabs(2)  # 修改\t制表符代表的空格数
print(expanded_name)  # China  First

(4)首字母大写(captalize)

text = 'hello world'
capitalized_text = text.capitalize()
print(capitalized_text)  # 'Hello world'

(5)大小写翻转(swapcase)

mixed_case = 'HeLLo WoRLd'
swapped_case = mixed_case.swapcase()
print(swapped_case)  # 'hEllO wOrlD'

(6)单词首字母大写(title)

sentence = 'the quick brown fox'
title_case = sentence.title()
print(title_case)  # 'The Quick Brown Fox'

【3】判断字符串类型

name = 'Lea4ning521'
print(name.isalnum())    # 字符串中既可以包含数字也可以包含字母,True
print(name.isalpha())    # 字符串中只包含字母,False
print(name.isidentifier())  # 字符串是否是合法标识符,True
print(name.islower())    # 字符串是否是纯小写,False
print(name.isupper())    # 字符串是否是纯大写,False
print(name.isspace())    # 字符串是否全是空格,False
print(name.istitle())    # 字符串中的单词首字母是否都是大写,False

【三】列表类型(list)

【1】内置方法

(1)类型强转

  • 但凡能被for循环遍历的数据类型都可以传给list()转换成列表类型

    • list()会跟for循环一样遍历出数据类型中包含的每一个元素然后放到列表中
  • # 示例
    string = 'hello'
    list_from_string = list(string)
    print(list_from_string)
    # 输出: ['h', 'e', 'l', 'l', 'o']
    
    tuple_example = (1, 2, 3)
    list_from_tuple = list(tuple_example)
    print(list_from_tuple)
    # 输出: [1, 2, 3]
    
    range_example = range(5)
    list_from_range = list(range_example)
    print(list_from_range)
    # 输出: [0, 1, 2, 3, 4]
    

(2)按索引存取值

  • 即可存也可以取

[1]正向取值

# 示例
numbers = [1, 2, 3, 4, 5]
first_number = numbers[0]
print(first_number)
# 输出: 1

[2]反向取值

  • # 示例
    numbers = [1, 2, 3, 4, 5]
    last_number = numbers[-1]
    print(last_number)
    # 输出: 5
    

[3]索引取值无则报错

  • 对于list来说,既可以按照索引取值,又可以按照索引修改指定位置的值,但如果索引不存在则报错

  • # 示例
    numbers = [1, 2, 3, 4, 5]
    index_10 = numbers[10]  # IndexError: list index out of range
    print(index_10)
    

(3)切片

[1]顾头不顾尾

# 示例
numbers = [1, 2, 3, 4, 5]
sliced_numbers = numbers[1:4]
print(sliced_numbers)
# 输出: [2, 3, 4]

[2]步长

# 示例
numbers = [1, 2, 3, 4, 5]
stepped_numbers = numbers[0:4:2]
print(stepped_numbers)
# 输出: [1, 3]

(4)计算长度

# 示例
numbers = [1, 2, 3, 4, 5]
length = len(numbers)
print(length)
# 输出: 5

(5)成员运算

[1]in

# 示例
numbers = [1, 2, 3, 4, 5]
contains_3 = 3 in numbers
print(contains_3)
# 输出: True

[2]not in

# 示例
numbers = [1, 2, 3, 4, 5]
not_contains_6 = 6 not in numbers
print(not_contains_6)
# 输出: True

(6)增加

[1]默认追加(.append())

  • append()默认追加到末尾(不管是什么类型的数据,都会当成一个整体元素填进去)

  • # 示例
    numbers = [1, 2, 3, 4, 5]
    numbers.append(6)
    print(numbers)
    # 输出: [1, 2, 3, 4, 5, 6]
    

[2]一次性添加多个(.extend())

  • extend()一次性在列表尾部添加多个元素、合并列表

  • # 示例
    list1 = [1, 2, 3]
    list1.extend([5, 6])
    print(list1)  # 输出: [1, 2, 3, 5, 6]
    list1.extend(['a', 'b'])
    print(list1)  # [1, 2, 3, 5, 6, 'a', 'b']
    list1.extend({'c': 9})
    print(list1)  # [1, 2, 3, 5, 6, 'a', 'b', 'c']
    

[3]指定位置添加(insert)

  • insert()在指定位置添加元素(索引位置,不管是什么类型的数据,都会当成一个整体元素填进去)

  • # 示例
    list1 = [1, 2, 3]
    list1.insert(0, '1')
    print(list1)
    # 输出: ['1', 1, 2, 3]
    

(7)删除

[1]del

  • 删除指定索引的元素

  • # 示例
    numbers = [1, 2, 3, 4, 5]
    del numbers[2]
    print(numbers)
    # 输出: [1, 2, 4, 5]
    

[2]pop

  • pop()默认删除列表最后一个元素,并将删除的值返回,括号内可以通过加索引值来指定删除元素

  • # 示例
    numbers = [1, 2, 3, 4, 5]
    popped_value = numbers.pop(2)
    print(popped_value)  # 输出: 3
    print(numbers)       # 输出: [1, 2, 4]
    

[3]remove

  • remove()括号内指名道姓表示要删除哪个元素,没有返回值

  • # 示例
    numbers = [1, 2, 3, 4, 3, 5]
    numbers.remove(3)
    print(numbers)  # 输出: [1, 2, 4, 3, 5]
    
  • 在这个例子中,remove(3) 删除了列表中的第一个值为 3 的元素。

  • 如果值不存在,会引发 ValueError 异常。

  • 这是与 pop() 不同的地方,pop() 是通过索引来删除元素的

(8)颠倒元素(reverse())

  • # 示例
    numbers = [1, 2, 3, 4, 5]
    numbers.reverse()
    print(numbers)  # 输出: [5, 4, 3, 2, 1]
    
  • 在这个例子中,reverse() 将列表中的元素颠倒,原来的第一个元素变成了最后一个,原来的最后一个元素变成了第一个

(9)元素排序(sort())

  • sort() 方法用于对列表进行排序,默认是升序排序。

  • # 示例
    numbers = [5, 2, 9, 1, 7]
    numbers.sort()
    print(numbers)  # 输出: [1, 2, 5, 7, 9]
    
  • 如果需要降序排序,可以使用 reverse 参数:

  • # 示例
    numbers = [5, 2, 9, 1, 7]
    numbers.sort(reverse=True)
    print(numbers)  # 输出: [9, 7, 5, 2, 1]
    
  • 需要注意的是,sort() 方法会直接修改原列表,而不会返回一个新的排序后的列表。

(10)元素排序(sorted())

  • 如果你需要保留原列表,可以使用 sorted() 函数

  • # 示例
    numbers = [5, 2, 9, 1, 7]
    sorted_numbers = sorted(numbers)
    print(sorted_numbers)  # 输出: [1, 2, 5, 7, 9]
    print(numbers)  # 输出: [5, 2, 9, 1, 7]
    
  • sort() 方法默认是按照元素的大小进行排序,如果需要自定义排序规则,可以使用 key 参数,传入一个函数

  • 例如,按照元素的绝对值进行排序:

  • # 示例
    numbers = [-5, 2, -9, 1, 7]
    numbers.sort(key=abs)
    print(numbers)  # 输出: [1, 2, -5, 7, -9]
    
  • key 参数指定的函数将应用于列表中的每个元素,用于提取排序的关键字。

(10)遍历循环

  • 遍历循环是对列表中的每个元素进行迭代或循环处理。常用的遍历方式有 for 循环和 while 循环。

[1]for 循环遍历列表

# 示例
fruits = ['apple', 'banana', 'orange']
for fruit in fruits:
    print(fruit)
# 输出:
# apple
# banana
# orange

[2]while 循环遍历列表

# 示例
fruits = ['apple', 'banana', 'orange']
index = 0
while index < len(fruits):
    print(fruits[index])
    index += 1
# 输出:
# apple
# banana
# orange
  • for 循环更加简洁,但 while 循环提供了更多的控制选项。
  • 通常情况下,推荐使用 for 循环遍历列表。

[3]遍历时获取索引

  • 如果需要同时获取元素的索引和值,可以使用 enumerate() 函数:
# 示例
fruits = ['apple', 'banana', 'orange']
for index, fruit in enumerate(fruits):
    print(f"Index: {index}, Fruit: {fruit}")
# 输出:
# Index: 0, Fruit: apple
# Index: 1, Fruit: banana
# Index: 2, Fruit: orange
  • 这样就可以在循环中同时获取元素的索引和值。

(11)步长操作

[1]正向步长

  • 正向步长是从列表的开头向末尾按指定步长取元素:

  • # 示例
    numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
    result = numbers[::2]  # 从头到尾,步长为2
    print(result)
    # 输出: [1, 3, 5, 7, 9]
    

[2]反向步长

  • 反向步长是从列表的末尾向开头按指定步长取元素:

  • # 示例
    numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
    result = numbers[::-2]  # 从尾到头,步长为2
    print(result)
    # 输出: [9, 7, 5, 3, 1]
    

[3]列表翻转

  • 列表翻转是指将列表中的元素顺序颠倒过来:
# 示例
numbers = [1, 2, 3, 4, 5]
print(numbers[::-1])  # 列表翻转
# 输出: [5, 4, 3, 2, 1]
  • 这些步长操作可以在遍历列表时提供更灵活的选项,根据需求选择不同的步长值以获取所需的元素。

(补充)字符串排序

  • 我们常用的数字类型直接比较大小,但其实,字符串、列表等都可以比较大小

  • 原理相同:都是依次比较对应位置的元素的大小,如果分出大小,则无需比较下一个元素

  • # 对列表中的数字进行排序
    l1 = [1, 2, 3]
    l2 = [2, ]
    print(l2 > l1)  # 默认按数字大小进行排序
    # True
    
    # 字符之间的大小取决于它们在ASCII表中的先后顺序,越往后越大
    s1 = 'abc'
    s2 = 'az'
    print(s2 > s1)  # s1与s2的第一个字符没有分出胜负,但第二个字符'z'>'b',所以s2>s1成立
    # True
    
    # 所以我们也可以对下面这个列表排序
    l = ['A', 'z', 'adjk', 'hello', 'hea']
    l.sort()
    print(l)  # ['A', 'adjk', 'hea', 'hello', 'z']
    
  • 当我们使用sort()方法对列表进行排序时,Python会按照以下原理进行比较和排序:

    • Python使用的是一种稳定的排序算法,通常是Timsort(合并排序和插入排序的混合算法)。
    • 对于字符串,比较的是字符的ASCII码值。在ASCII码表中,大写字母在小写字母之前,因此大写字母会排在小写字母的前面。在你提供的例子中,'A'的ASCII码小于'adjk'中的任何字符,而'z'的ASCII码大于其他所有字符。
    • 对于字符串列表,Python按照元素的字典顺序进行比较。首先比较第一个元素,如果相等则继续比较下一个元素,以此类推。
  • 在上述例子中,列表['A', 'z', 'adjk', 'hello', 'hea']会按照以下步骤排序:

    • 'A''adjk'比较,由于'A'的ASCII码小,所以 'A' 排在前面。
    • 'adjk''hea'比较,由于'adjk'的ASCII码小,所以 'adjk' 排在前面。
    • 'hea''hello'比较,由于'hea'的ASCII码小,所以 'hea' 排在前面。
    • 'hello''z'比较,由于'hello'的ASCII码小,所以 'hello' 排在前面。
    • 最后是 'z',它是最大的,所以 'z' 排在最后。
  • 最终,排序后的列表为['A', 'adjk', 'hea', 'hello', 'z']

【四】元组类型(tuple)

内置方法

(1)类型强转

  • 但凡能被for循环的遍历的数据类型都可以传给tuple()转换成元组类型

  • 使用tuple()函数可以将其他可迭代对象转换为元组

  • # 示例
    numbers_list = [1, 2, 3, 4, 5]
    numbers_tuple = tuple(numbers_list)
    print(numbers_tuple)  # 输出: (1, 2, 3, 4, 5)
    

(2)索引取值

  • 与列表类似,元组也支持按索引存取值

[1]正索引取值

# 示例
fruit_tuple = ('apple', 'banana', 'cherry')
print(fruit_tuple[1])  # 输出: banana

[2]负索引取值

# 示例
fruit_tuple = ('apple', 'banana', 'cherry')
print(fruit_tuple[-1])  # 输出: cherry

[3]只能取不能改

  • 与列表相同,如果索引不存在,会抛出IndexError

  • # 示例
    fruit_tuple = ('apple', 'banana', 'cherry')
    print(fruit_tuple[3])  # IndexError: tuple index out of range
    # 可以取值,但不可以修改
    print(fruit_tuple[0])
    fruit_tuple[1] = 'pineapple' # TypeError: 'tuple' object does not support item assignment
    
  • 当索引取值的内容为可变类型时可以修改

  • tuple1 = ('key', 'value', ['a', 'b'])
    tuple1[2][0]= 'c'
    print(tuple1)   # ('key', 'value', ['c', 'b'])
    
    tuple1 = ('key', 'value', {'a': 'b'})
    tuple1[2]['a']= 'z'
    print(tuple1)   # ('key', 'value', {'a': 'z'})
    

(3)切片(顾头不顾尾)

  • 与列表一样,元组也支持切片操作

[1]顾头不顾尾

# 示例
fruit_tuple = ('apple', 'banana', 'cherry', 'date', 'elderberry')
print(fruit_tuple[1:4])  # 输出: ('banana', 'cherry', 'date')

[2]步长

# 示例
numbers_tuple = (1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
print(numbers_tuple[::2])  # 输出: (1, 3, 5, 7, 9)

(4)计算长度len()

  • 使用len()函数可以获取元组的长度

  • # 示例
    fruit_tuple = ('apple', 'banana', 'cherry')
    print(len(fruit_tuple))  # 输出: 3
    

(5)成员运算in / not in

  • 与列表相同,元组也支持innot in运算符

[1]in

# 示例
fruit_tuple = ('apple', 'banana', 'cherry')
print('banana' in fruit_tuple)  # 输出: True
print('orange' not in fruit_tuple)  # 输出: True

[2]not in

# 示例
fruit_tuple = ('apple', 'banana', 'cherry')
print('orange' not in fruit_tuple)  # 输出: True

(6)遍历循环

  • 使用for循环可以遍历元组中的每个元素

  • # 示例
    fruit_tuple = ('apple', 'banana', 'cherry')
    for fruit in fruit_tuple:
        print(fruit)
    # 输出:
    # apple
    # banana
    # cherry
    

(7)元组拼接(+)

  • 使用+运算符可以将两个元组拼接成一个新的元组

  • # 示例
    tuple1 = (1, 2, 3)
    tuple2 = ('a', 'b', 'c')
    result_tuple = tuple1 + tuple2
    print(result_tuple)  # 输出: (1, 2, 3, 'a', 'b', 'c')
    

(8)元组重复(*)

  • 使用*运算符可以将元组重复指定次数

  • # 示例
    fruit_tuple = ('apple', 'banana', 'cherry')
    result_tuple = fruit_tuple * 2
    print(result_tuple)
    # 输出: ('apple', 'banana', 'cherry', 'apple', 'banana', 'cherry')
    

【五】字典类型(dict)

【1】字典类型定义

  • 字典(Dictionary)是一种无序的数据集合,使用键(key)和值(value)之间的映射关系来存储数据。

  • 字典是Python中唯一的映射类型,其它语言中可能称为关联数组或哈希表。

  • 字典的特点:

    • 字典中的数据是无序的,不能通过索引来访问,而是通过键来访问。
    • 字典中的键必须是不可变的,通常使用字符串、数字或元组作为键。
    • 字典中的值可以是任意类型,包括数字、字符串、列表、字典等。
  • 字典的创建使用花括号 {},并使用冒号 : 分隔键和值。

  • 多个键值对之间使用逗号 , 分隔。

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    

【2】定义

  • 定义字典时,键和值之间使用冒号 : 分隔,多个键值对之间使用逗号 , 分隔。

  • 字典的键必须是不可变的,通常使用字符串、数字或元组作为键。

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    
  • 在定义字典时,也可以使用 dict 函数

# 示例
person_info = dict(name='Dream', age=25, gender='male')

【3】内置方法

(1)取值

[1]按[key]取值

  • 使用中括号加键名的方式可以直接获取字典中对应键的值

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    print(person_info['name'])  # 输出: Dream
    

[2]get取值

  • 使用get方法可以根据键获取对应的值,如果键不存在,则返回指定的默认值(默认为None

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    print(person_info.get('name'))  # 输出: Dream
    # 取不到'height'的键,可以指定默认值
    print(person_info.get('height'))  # None
    print(person_info.get('height', 175))  # 输出: 175
    

(2)计算长度

  • 使用len函数可以计算字典中键值对的个数

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    length = len(person_info)
    print(length)  # 输出: 3
    

(3)成员运算

  • 使用innot in可以判断一个键是否存在于字典中

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    print('name' in person_info)  # 输出: True    # 只可以判断键(key),无法判断值是否在字典中
    print('male' in person_info)   # False
    print('height' not in person_info)  # 输出: True
    

(4)增加

[0]赋值增加

# 字典为空时,索引没有的keys并且赋值,可自动添加至字典
dict1 = {}
dict1['a'] = 1
print(dict1)   # {'a':1}

# 字典不为空时,索引没有的key并且赋值,同样可自动添加至字典
dict1 = {'b':2,'c':3}
dict1['a'] = 1
print(dict1)   # {'b': 2, 'c': 3, 'a': 1}

[1]新增键值对(update())

  • 使用update方法可以批量新增键值对,如果键已经存在,则更新对应的值

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    person_info['height'] = 175
    print(person_info)  # 输出: {'name': 'Dream', 'age': 25, 'gender': 'male', 'height': 175}
    

[2]批量新增键值对(update())

  • 使用update方法可以批量新增键值对,如果键已经存在,则更新对应的值

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    person_info.update({'height': 175, 'weight': 70})
    print(person_info)  # 输出: {'name': 'Dream', 'age': 25, 'gender': 'male', 'height': 175, 'weight': 70}
    

[3]增加值并返回值(setdefault())

  • setdefault(key, default) 方法用于获取指定键的值,如果键不存在,则返回默认值,并在字典中添加键值对。

  • # 示例
    person_info = {'name': 'Tony', 'age': 25}
    
    # 使用setdefault()获取键值,如果键不存在,则添加新键值对
    gender = person_info.setdefault('gender', 'male')
    print(gender)        # 输出: male
    print(person_info)   # 输出: {'name': 'Tony', 'age': 25, 'gender': 'male'}
    
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    add_dict = person_info.setdefault('key','value')
    print(add_dict)    # value
    print(person_info)   # {'name': 'Dream', 'age': 25, 'gender': 'male', 'key': 'value'}
    
  • 如果字典中存在键 'gender',则 setdefault() 方法返回对应的值;

  • 如果不存在,则添加新键值对 'gender': 'male' 并返回默认值 'male'

(5)删除

[1]按键删除(del())

  • 使用del关键字可以根据键删除字典中的键值对

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    del person_info['age']
    print(person_info)  # 输出: {'name': 'Dream', 'gender': 'male'}
    

[2]弹出键值对(pop())

  • 使用pop方法可以根据键弹出字典中的键值对,同时返回被弹出的值

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    popped_value = person_info.pop('age')
    print(popped_value)  # 输出: 25
    print(person_info)  # 输出: {'name': 'Dream', 'gender': 'male'}
    

[3]清空字典(clear())

  • 使用clear方法可以清空字典中的所有键值对

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    person_info.clear()
    print(person_info)  # 输出: {}
    

[4]随机删除键值对(popitem())

  • popitem() 方法用于随机删除字典中的一个键值对,并以元组的形式返回被删除的键值对。

  • 字典是无序的,所以删除的是一个随机的键值对。

  • # 示例
    person_info = {'name': 'Tony', 'age': 25, 'gender': 'male'}
    
    # 随机删除一个键值对
    removed_item = person_info.popitem()
    print(removed_item)  # 输出: ('gender', 'male')
    print(person_info)   # 输出: {'name': 'Tony', 'age': 25}
    
  • popitem() 在 Python 3.7+ 中删除的是字典中的“末尾”键值对,但在旧版本的 Python 中,删除的并不是末尾的键值对。

  • 所以在使用 popitem() 时要注意版本兼容性。

(6)键对(keys())

  • 使用keys方法可以获取字典中所有的键,返回一个可迭代的视图对象

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    keys = person_info.keys()
    print(keys)  # 输出: dict_keys(['name', 'age', 'gender'])
    

(7)值对(values())

  • 使用values方法可以获取字典中所有的值,返回一个可迭代的视图对象

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    values = person_info.values()
    print(values)  # 输出: dict_values(['Dream', 25, 'male'])
    

(8)键值对(items())

  • 使用items方法可以获取字典中所有的键值对,返回一个可迭代的视图对象

  • # 示例
    person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
    items = person_info.items()
    print(items)  # 输出: dict_items([('name', 'Dream'), ('age', 25), ('gender', 'male')])
    

(9)遍历循环

[1]只遍历key

# 示例
person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
for key in person_info:
    print(key)
# 输出:
# name
# age
# gender

[2]只遍历value

# 示例
person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
for value in person_info.values():
    print(value)
# 输出:
# Dream
# 25
# male

[3]遍历key和value

# 示例
person_info = {'name': 'Dream', 'age': 25, 'gender': 'male'}
for key, value in person_info.items():
    print(f'{key}: {value}')
# 输出:
# name: Dream
# age: 25
# gender: male

(10)字典排序(sorted())

  • 字典的排序是通过字典的键来进行的,使用 sorted() 函数可以对字典进行排序。

  • # 示例
    my_dict = {'apple': 5, 'banana': 2, 'orange': 8, 'grape': 1}
    
    # 对字典按键排序,并返回一个列表
    sorted_dict = sorted(my_dict.items())
    print(sorted_dict)
    # 输出: [('apple', 5), ('banana', 2), ('grape', 1), ('orange', 8)]
    
  • 在示例中,sorted() 函数对字典 my_dict 的键进行了排序,返回了一个按键排序的元组列表。

  • 如果需要按值进行排序,可以使用 key 参数指定排序的关键字:

  • # 示例
    my_dict = {'apple': 5, 'banana': 2, 'orange': 8, 'grape': 1}
    
    # 对字典按值排序,并返回一个列表
    sorted_dict = sorted(my_dict.items(), key=lambda x: x[1])
    print(sorted_dict)
    # 输出: [('grape', 1), ('banana', 2), ('apple', 5), ('orange', 8)]
    
  • 在这个示例中,key 参数指定了按值排序,并使用了 lambda 函数提取元组中的第二个元素(值)作为排序的关键字。

【六】集合类型(set)

【1】集合类型定义

  • 集合(Set)是 Python 中的一种无序且不重复的数据类型。
  • 集合类型的定义使用大括号 {},元素之间使用逗号 , 分隔。

【2】定义

  • 集合的定义方式与示例中的方式相同,使用大括号 {} 并将元素用逗号 , 分隔。

  • # 示例
    my_set = {1, 2, 3, 4, 5}
    print(my_set)  # 输出: {1, 2, 3, 4, 5}
    

【3】内置方法

(0)类型强转

  • 但凡能被for循环的遍历的数据类型(强调:遍历出的每一个值都必须为不可变类型)都可以传给set()转换成集合类型

  • # 示例
    my_list = [1, 2, 2, 3, 4, 4, 5]
    
    # 使用set()将列表转换为集合
    my_set = set(my_list)
    print(my_set)
    # 输出: {1, 2, 3, 4, 5}
    
  • 在这个示例中,my_list 是一个包含重复元素的列表,通过使用 set() 将其转换为集合,得到了一个去重后的集合 my_set

(1)添加元素

[1] 添加单个元素(add())

  • add(element) 方法用于向集合中添加单个元素。

  • # 示例
    my_set = {1, 2, 3}
    my_set.add(4)
    print(my_set)  # 输出: {1, 2, 3, 4}
    

[2]添加多个元素(update())

  • update(iterable) 方法用于向集合中添加多个元素,参数是一个可迭代对象。

  • # 示例
    my_set = {1, 2, 3}
    my_set.update([3, 4, 5])
    print(my_set)  # 输出: {1, 2, 3, 4, 5}
    

(2)删除元素

[1] 删除指定元素(remove())

  • remove(element) 方法用于移除集合中的指定元素,如果元素不存在则会引发 KeyError。

  • # 示例
    my_set = {1, 2, 3, 4, 5}
    my_set.remove(3)
    print(my_set)  # 输出: {1, 2, 4, 5}
    

[2] 删除指定元素(discard())

  • discard(element) 方法用于移除集合中的指定元素,如果元素不存在则不会引发错误。

  • # 示例
    my_set = {1, 2, 3, 4, 5}
    my_set.discard(3)
    print(my_set)  # 输出: {1, 2, 4, 5}
    

[3] 随机删除元素(pop())

  • pop() 方法用于随机移除集合中的一个元素,如果集合为空则引发 KeyError。

  • # 示例
    my_set = {1, 2, 3, 4, 5}
    removed_element = my_set.pop()
    print(removed_element)  # 输出: 随机移除的元素
    print(my_set)           # 输出: 移除后的集合
    
    # 数字类型顺序将不会出现变化,将会删除数字1
    # 字符串类型将会随机删除元素
    my_set = {'a', 'b', 'v'}
    removed_element = my_set.pop()
    print(removed_element)  # 输出: 随机移除的元素
    print(my_set)  # 输出: 移除后的集合
    # 第一次:{'v', 'b'}
    # 第二次:{'b', 'a'}
    

(3)集合操作

[1] 并集(union() / | )

  • union(*others) 方法返回当前集合与其他集合的并集。

  • # 示例
    set1 = {1, 2, 3}
    set2 = {3, 4, 5}
    union_set = set1.union(set2)
    print(union_set)  # 输出: {1, 2, 3, 4, 5}
    
    # |
    set1 = {1, 2, 3}
    set2 = {4, 5, 6}
    print(set1 | set2)    # {1, 2, 3, 4, 5, 6}
    

[2] 交集(intersection() / & )

  • intersection(*others) 方法返回当前集合与其他集合的交集。

  • # 示例
    set1 = {1, 2, 3}
    set2 = {3, 4, 5}
    intersection_set = set1.intersection(set2)
    print(intersection_set)  # 输出: {3}
    
    # &
    set1 = {1, 2, 3}
    set2 = {3, 4, 5}
    print(set1 & set2)  # {3}
    

[3] 差集(difference() / - )

  • difference(*others) 方法返回当前集合与其他集合的差集。

  • # 示例
    set1 = {1, 2, 3}
    set2 = {3, 4, 5}
    difference_set = set1.difference(set2)
    print(difference_set)  # 输出: {1, 2}
    
    # -
    set1 = {1, 2, 3}
    set2 = {3, 4, 5}
    print(set1 - set2)  # {1, 2}
    print(set2 - set1)  # {4, 5}
    

[4] 对称差集(symmetric_difference() / ^)

  • symmetric_difference(other) 方法返回当前集合与其他集合的对称差集。

  • 两个集合各自独有的部分,并将他们合并至一个集合中

  • 两个人各自的好友,去掉共同的好友

  • # 示例
    set1 = {1, 2, 3}
    set2 = {3, 4, 5}
    symmetric_difference_set = set1.symmetric_difference(set2)
    print(symmetric_difference_set)  # 输出: {1, 2, 4, 5}
    
    # ^
    set1 = {1, 2, 3}
    set2 = {3, 4, 5}
    print(set1 ^ set2)  # {1, 2, 4, 5}
    

[5]父集

set1 = {1, 2, 3, 4, 5}
set2 = {2, 4}

# 判断 set1 是否是 set2 的父集
is_superset = set1.issuperset(set2)
print(is_superset)
# 输出: True

[6]子集

set1 = {1, 2, 3, 4, 5}
set2 = {2, 4}

# 判断 set2 是否是 set1 的子集
is_subset = set2.issubset(set1)
print(is_subset)
# 输出: True

[7]判断(==)

set1 = {1, 2, 3, 4, 5}
set2 = {2, 4}

# 判断两个集合是否相等
is_equal = set1 == set2
print(is_equal)
# 输出: False

(4)去重

  • 只能针对不可变类型

  • 集合本身是无序的,去重之后无法保留原来的顺序

  • l_old = ['a', 'b', 1, 'a', 'a']
    s = set(l_old)  # 将列表转成了集合
    print(s)
    # {'b', 'a', 1}
    
    l_new = list(s)  # 再将集合转回列表
    print(l_new)  # 去除了重复,但是打乱了顺序
    # ['b', 'a', 1]
    
    
    # 针对不可变类型,并且保证顺序则需要我们自己写代码实现,例如
    l_second = [
        {'name': 'lili', 'age': 18, 'sex': 'male'},
        {'name': 'jack', 'age': 73, 'sex': 'male'},
        {'name': 'tom', 'age': 20, 'sex': 'female'},
        {'name': 'lili', 'age': 18, 'sex': 'male'},
        {'name': 'lili', 'age': 18, 'sex': 'male'},
    ]
    
    new_l_second = []
    
    for dic in l_second:
        if dic not in new_l_second:
            new_l_second.append(dic)
    
    print(new_l_second)
    # 结果:既去除了重复,又保证了顺序,而且是针对不可变类型的去重
    '''
    [
    {'name': 'lili', 'age': 18, 'sex': 'male'}, 
    {'name': 'jack', 'age': 73, 'sex': 'male'}, 
    {'name': 'tom', 'age': 20, 'sex': 'female'}
    ]
    '''
    

(5)计算长度(len())

# 计算集合长度
length = len(unique_set)
print(length)
# 输出: 5

(6)遍历循环

my_set = {1, 2, 3, 'a', 'b'}

# 遍历集合
for item in my_set:
    print(item)
# 输出: 1 2 3 'a' 'b'

(7)成员运算

[1]in

is_in_set = 'a' in my_set
print(is_in_set)
# 输出: True

[2]not in

is_not_in_set = 6 not in my_set
print(is_not_in_set)
# 输出: True

【七】案例

# 计算单词出现的次数,以字典形式返回值
s = 'dream say hello hello hello sb sb sb sb jerry jerry nice nice nice'
dict_data = {}
list_str = s.split()
set_str = set(list_str)
for i in set_str:
    dict_data.update({i: s.count(i)})
print(dict_data)   # {'hello': 3, 'dream': 1, 'sb': 4, 'jerry': 2, 'nice': 3, 'say': 1}
# 计算字符出现的次数
s = 'dream say hello hello hello sb sb sb sb jerry jerry nice nice nice'
dict_s = {}
for i in s:
    if i not in dict_s:
        dict_s[i] = 1
    else:
        dict_s[i] += 1
print(dict_s)
# {'d': 1, 'r': 5, 'e': 9, 'a': 2, 'm': 1, ' ': 13, 's': 5, 'y': 3, 'h': 3, 'l': 6, 'o': 3, 'b': 4, 'j': 2, 'n': 3, 'i': 3, 'c': 3}

标签:输出,内置,name,示例,Python,age,数据类型,字符串,print
From: https://www.cnblogs.com/Lea4ning/p/17879766.html

相关文章

  • 神经网络Python代码完整版及其代码解析
     1、读取数据集和标签集1defloadDataSet():2data=[]3label=[]4fr=open('testSet.txt')5forlineinfr.readlines():#循环读写,fr是一个已经打开的文件对象,readline()函数会读取文件中的一行内容6lineArr=lin......
  • python07
    推导式:使用推导式可以快速生成列表、元组、字典以及集合类型的数据1.列表推导式①:基本格式格式:【exp for x in list】for--in-- 用于遍历列表(或者其他可迭代对象)exp 用于对每层循环中的列表元素进行运算  #用循环在列......
  • [Python急救站]百钱买百鸡
    百钱买百鸡:一人用100元买了100只鸡,其中公鸡5元一只,母鸡3元一只,小鸡1元一只。问:公鸡、母鸡、小鸡各多少只?程序采用穷举法。forxinrange(1,21):foryinrange(1,34):z=100-x-yif5*x+3*y+z/3==100:print("公鸡数量:{},......
  • 代码随想训练营第五十七天(Python)| 647. 回文子串、516.最长回文子序列
    647.回文子串1、中心扩散法+双指针classSolution:defcountSubstrings(self,s:str)->int:res=0foriinrange(len(s)):#以i为中心res+=self.countPalind(i,i,s,len(s))#以i和i+1为中心......
  • 【Python 千题 —— 基础篇】取余计算
    题目描述题目描述编写一个程序,接受用户输入的两个数字,然后计算这两个数字取余后的结果,并输出结果。输入描述输入两个数字,用回车隔开两个数字。输出描述程序将计算这两个数字取余后的结果,并输出结果。示例示例①73输出:1.0代码讲解下面是本题的代码:#描述:编写一个程序,接受用户输......
  • 【Python 千题 —— 基础篇】成绩评级
    题目描述题目描述期末考试结束,请根据同学的分数为该同学评级。A:90~100B:80~89C:70~79D:60~69E:0~60输入描述输入同学的分数。输出描述输出该同学的等级。示例示例①输入:79输出:同学的等级是:C代码讲解下面是本题的代码:#描述:期末考试结束,请根据同学的分数为该同学评级。#A......
  • python 协程
    python:用@asyncio.coroutine装饰器生成的对象是一个生成器对象但不是协程对象        用async定义的函数对象不是一个生成器,但是一个协程对象 importasynciofromcollections.abcimportCoroutine,Generator@asyncio.coroutinedeffun():print('......
  • Python学习前准备之MarkDown语法基础
    MarkDown基础语法[一]Typora(1)下载官网:Typora官方中文站(typoraio.cn)正版价格及介绍:89元/3台设备;89元三个设备码(重装系统设备码失效)绿色版:网盘链接[.\Typora\resources文件夹下替换(app.asar)](2)部分设置主题更改:Typora官方主题库下载完成后,解压压缩包后将.css......
  • Python基础之计算机基础
    计算机基础【一】计算机组成原理(1)什么是计算机?计算机是一种通电的智能设备,被称为电脑,拥有处理数据、执行指令的能力,是现代科技和信息社会的重要工具电脑又可以理解为通电的大脑电脑二字蕴含了人类对计算机的终极期望,希望它能真的像人脑一样去工作,实现自动化,提高工作效率,解......
  • Python学习前准备之Python环境安装和Pycharm使用
    【一】python解释器安装【1】Python官网https://www.python.org【2】Python各版本解释器官网https://www.python.org/downloads/【二】Windows系统安装Python解释器【1】下载Python版本解释器现在已经更新到了3.13版本的Python解释器,但是最新的解释器往往都会存在一......