什么是类型转换?—> 将自身的数据类型变成新的数据类型,并拥有新的数据类型的所有功能的过程即为类型转换
为什么做类型转换?—> 为了方便更好的帮助处理业务,将类型变更为更适合业务场景的类型
举例:比如 a = '1' ,这是一个字符串类型,所以它无法执行数字类型的操作。
str —> number :必须是由数字组成的字符串才可以通过类型转换转为数字类型
int_str = '1024' ; float_str = '3.1415926'
number —> str : 无任何要求
原始类型 | 目标类型 | 函数 | 举例 |
---|---|---|---|
整型 | 字符串 | str | new_str = str(123456) |
浮点型 | 字符串 | str | new_str = str(3.1515926) |
字符串 | 整型 | int | new_int = int(‘1234’) |
字符串 | 浮点型 | int | new_float = int(‘3.1415926’) |
示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
str_int = '1024' new_int = int(int_str) print(new_int)
# 执行结果如下: # >>> 1024 # >>> <class 'int'>
int_str = 3.1415926 new_str = str(int_str) print(new_str) print(type(new_str))
# 执行结果如下: # >>> 3.1415926 # >>> <class 'str'>
int_and_str = '123abc' # 只有数字组成的字符串才可以通过类型转换转为数字类型 new_int = int(int_and_str) print(new_int)
# 执行结果如下: # >>> ValueError: invalid literal for int() with base 10: '123abc' |
split() 函数 的功能:将字符串以一定的规则切割,并转换成列表。
split() 函数 的用法:string.split(sep=Node, maxsplit=-1) ;
示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
name = 'My name is Neo' name_list = name.split()
print(name_list)
# 执行结果如下: # >>> ['My', 'name', 'is', 'Neo'] # >>> 可以看到已经将 'name' 以空格为切割规则符号切割成了每个单词为一个元素的列表
test_int = '1, 2, 3, 4' test_int_list = test_int.split(',')
print(test_int_list)
# 执行结果如下: # >>> ['1', ' 2', ' 3', ' 4'] # >>> 可以看到已经将 'test_int' 以逗号为切割规则符号切割成了每个单词为一个元素的列表
test_str = 'a|b|c|d|e' test_str_list = test_str.split('|', 2)
print(test_str_list)
# 执行结果如下: # >>> ['a', 'b', 'c|d|e'] # >>> 可以看到已经将 'test_str_list' 以 '|' 为切割规则符号切割成了两次
error_str = ' a~b~c ' test_error_str = error_str.split('') print(test_error_str)
# 执行结果如下: # >>> ValueError: empty separator 注意:split()函数是不可以用空字符串作为切割规则符号的 |
split() 函数 的功能:将列表以一定的规则切割,并转换成字符串。
split() 函数 的用法:'sep'.join(iterable) ;
示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
test_info = ['a', 'b', 'c'] new_info = '-'.join(test_info)
print(new_info)
# 执行结果如下: # >>> a-b-c
test_info_int = [1, 2, 3, 4] new_info_int = '-'.join(test_info_int)
print(new_info_int)
# 执行结果如下: # >>> TypeError: sequence item 0: expected str instance, int found
test_info_tuple = [(1, ), (2, 3, 4)] new_info_tuple= '-'.join(test_info_tuple)
print(new_info_tuple)
# 执行结果如下: # >>> TypeError: sequence item 0: expected str instance, int found |
将字符串 'a e f h j k d l' , 转换为列表并进行排序,然后再转为字符串。
代码示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
sort_str = 'a e f h j k d l' sort_str_list = sort_str.split(' ') print(sort_str_list)
# 执行结果如下: # >>> ['a', 'e', 'f', 'h', 'j', 'k', 'd', 'l']
sort_str_list.sort() print(sort_str_list)
# 执行结果如下: # >>> ['a', 'd', 'e', 'f', 'h', 'j', 'k', 'l']
sort_str = '|'.join(sort_str_list) print(sort_str) print(type(sort_str))
# 执行结果如下: # >>> a|d|e|f|h|j|k|l # >>> <class 'str'> |
sorted() 函数区别于 sort() 函数。sort() 函数为列表的内置函数,而sorted() 函数为python的内置函数,可以处理所有的数据类型。
示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
sort_str_new = 'aefhjkdc' result = sorted(sort_str_new)
print(result)
# 执行结果如下: # >>> ['a', 'c', 'd', 'e', 'f', 'h', 'j', 'k']
print(''.join(result))
# 执行结果如下: # >>> acdefhjk |
什么是 bytes ?(比特类型) —> bytes 是一种二进制数据流,也是一种可传输的类型,在各个编程语言中都存在。也可以认为它是一种特殊的字符串,因为它长得和字符串几乎一模一样,同时也拥有字符串几乎所有的内置函数。我们完全可以像操作字符串一样操作 比特类型 (bytes),只不过字符串前需要加上 b 的标识。
示例如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
bt = b'my name is Neo' print('\'bt\'的值为:', bt, ';\'bt\'的类型为:', type(bt))
# 执行结果如下: # >>> 'bt'的值为: b'my name is Neo' ;'bt'的类型为: <class 'bytes'>
print(bt.capitalize())
# 执行结果如下: # >>> b'My name is neo'
print(bt.replace('Neo', 'Jack'))
# 执行结果如下: # >>> TypeError: a bytes-like object is required, not 'str' 这里的报错是因为我们替换的类型为字符串类型,正确的写法如下
print(bt.replace(b'Neo', b'Jack'))
# 执行结果如下: # >>> b'my name is Jack'
print(bt[0]) print(bt[-1]) print(bt[3:8])
# 执行结果如下: # >>> 109 这里的109是 'n' 的二进制流的显示方式 # >>> 111 这里的111是 'o' 的二进制流的显示方式 # >>> b'name '
print('\'N\'字符的索引位置为:', bt.find(b'N'))
# 执行结果如下: # >>> 'N'字符的索引位置为: 11
test_info = b'my name is \'李雷\'' print(test_info)
# 执行结果如下: # >>> SyntaxError: bytes can only contain ASCII literal characters. # 报错信息为"bytes"类型只支持ASCII码的字符 # 由此也引出了下文的 encode() 函数 与 decode() 函数 |
encode() 函数 的功能:将字符串转为比特(byte)类型
encode() 函数 用法:
用法:string.encode(encoding='utf-8', errors='strict')
参数:encoding 与 errors
示例如下:
1 2 3 4 5 6 7 8 |
test_str = 'my name is HanMeimei' bytes_str = test_str.encode('utf-8') print(bytes_str) print(type(bytes_str))
# 执行结果如下: # >>> b'my name is HanMeimei' # >>> <class 'bytes'> |
decode() 函数 的功能:将比特(byte)类型转为字符串
decode() 函数 用法:
用法:string.encode(encoding='utf-8', errors='strict') ;
参数:encoding 与 errors; 注意,这里的 encoding 是解码的作用,encode() 函数 的 encoding 是 编码的作用。
示例如下:
1 2 3 4 5 6 7 8 |
bytes_str = b'Python is very good' test_str = bytes_str.decode('utf-8') print(test_str) print(type(test_str))
# 执行结果如下: # >>> Python is very good # >>> <class 'str'> |
1 2 3 4 5 6 7 8 9 10 11 |
str_date = 'my name is \'亚当\'' byte_date = str_date.encode('utf-8') print(byte_date)
# 执行结果如下: # >>> b"my name is '\xe4\xba\x9a\xe5\xbd\x93'" 这是 utf-8 转化的中文的样子
print(byte_date.decode('utf-8'))
# 执行结果如下: # >>> my name is '亚当' |
原始类型 | 目标类型 | 函数 | 举例 |
---|---|---|---|
列表 | 集合 | set | new_set = set([1, 2, 3, 4, 5]) |
列表 | 元组 | tuple | new_tuple = ([1, 2, 3, 4, 5] |
元组 | 集合 | set | new_set = set((1, 2, 3, 4, 5)) |
元组 | 列表 | list | new_set = set((1, 2, 3, 4, 5)) |
集合 | 列表 | list | new_list = list({1, 2, 3, 4, 5}) |
集合 | 元组 | tuple | new_tuple = tuple({1, 2, 3, 4, 5}) |