day07——数据类型补充、坑、二次编码
day07
数据类型补充
str
- 首字母大写:capitalize()
name = 'alex'
name1 = name.capitalize()
print(name1)
- 每个单词首字母大写:title()
name = 'alex wusir'
print(name.title())
- 大小写反转:swapcase()
name = "Alex"
print(name.swapcase())
- 居中(填充):center(总占位数,填充内容)
name = 'alex'
print(name.center(20))
name = 'alex'
print(name.center(20,'-'))
- -09查找:find(内容) 从左向右只查一个,返回索引位置,没有就返回-1
index(内容):从左向右只查一个,返回索引位置,查找不存在的就报错
name = "alelx"
print(name.find("b")) #find查找不存在的返回-1
print(name.index("b")) #index查找不存在的就报错
- 拼接:'符号'.join()
name = "al3x"
print("_".join(name)) ***
- 格式化:1)%s %d 、2)f 、3)name.format()
{}配合format(添加内容个数与{}个数对应)
{数字}配合format(内容),按照索引值
{字母}配合format(字母 = ’内容‘) 按照关键字进行填充
# 1.%s
# 2.f
# 3.name.format()
# name = "alex{},{},{}"
# print(name.format(1,2,3)) # 按照顺序位置进行填充
# name = "alex{2},{0},{1}"
# print(name.format("a","b","c")) # 按照索引值进行填充
# name = "alex{a},{b},{c}"
# print(name.format(a=1,c=11,b=67)) # 按照关键字进行填充
-*字符串都会开辟一个新空间
# + * 开辟新的空间
# name = "alex"
# name1 = "wusir"
# print(id(name))
# print(id(name1))
# print(id(name + name1))
list
定义方式:
list('123')
其他方法:
排序:sort() 默认升序,如果是中文,以码来排序
降序:sort(reverse = True)
lst = [1,2,23,234,435,36,23,213421,421,4231,534,65]
lst.sort()
print(lst)
lst = ["你好","我好"]
lst.sort()
print(lst)
lst.sort(reverse=True) # 降序
反转:reverse() 或者 lst[::-1]
# lst = [1,2,3,4453,5,6,7]
# print(lst[::-1])
# lst.reverse() # 反转
# print(lst)
# lst = [1,2,3,4,5123,21345,231123,4,1235,234,123]
# lst.sort()
# lst.reverse()
# print(lst)
查找: index
面试题:
# lst = [[]]
# new_lst = lst * 5
# new_lst[0].append(10)
# print(new_lst)
# lst = [1,[]]
# new_lst = lst * 5
# new_lst[0] = 10
# print(new_lst)
# lst = [1,[]]
# new_lst = lst * 5
# new_lst[1] = 10
# print(new_lst)
把一个列表追加到另外一个列表中
+*元素都是共用的
方式一:
lst.extend(lst1)
print(lst)
方式二:
print(lst+lst1)
new_lst = lst * 5
print(id(new_lst[0]),id(new_lst[0]))
# lst = [[]]
# new_lst = lst * 5
# new_lst[0].append(10)
# print(new_lst)
tuple
(1,)也是元组
# tu = (1,) # (1,)是元组# print(type(tu))
(1) 括号里数据本身的类型
# tu = ("12") # 数据类型是()中数据本身
# print(type(tu))
元组 + * 不可变共用,可变也共用
dict
定义字典:
dict(key = 1,key2 = 2)
随机删除:popitem
返回的是被删除的键值对,以元组的形式:(键,值),python3.6以上默认删除最后一个
# dic = {"key":1,"key2":2,"key3":56}
# print(dic.popitem()) # 返回的是被删除的键值对(键,值)
# print(dic)
# python36 默认删除最后一个
fromkeys("可迭代的键",共用的值)
# dic = {}
# dic.fromkeys("123",[23]) # 批量添加键值对{"1":[23],"2":[23],"3":[23]}
# print(dic)
# dic = dict.fromkeys("123456789",1) # 批量添加键值对"键是可迭代对象",值 -- 会被共用
# dic["1"] = 18
# print(dic)
set
set() ——空集合
{} ——空字典
定义集合:
set('alex') #迭代添加
bool: False
数字:0
字符串:""
列表:[]
元组:()
字典:{}
集合:set()
其他:None
数据类型之间的转换
# list tuple
lst = ['1', '2', '3']
tu = tuple(lst)
print(tu)
# tuple list
tu = ('1', '2', '3')
lst = list(tu)
print(lst)
————————————————————————————————
# str list
name = "alex"
print(name.split())
# list str
lst = ["1","2","3"]
print(''.join(lst))
—————————————————————————————————
# dict -- str
dic = {"1":2}
print(str(dic),type(str(dic)))
str -- dict
# print(dict("{1:1}")) # 报错
—————————————————————————————————
# set - list
s = {1,2,3,4}
print(list(s))
# list - set
lst = [1, 2, 3, 4]
print(set(lst))
python数据类型:
# python数据类型:
# 可变:
# list ,dict ,set
# 不可变:
# int bool str tuple
# 有序:
# list,tuple,str,int,bool
# 无序:
# dict,set
# 取值方式:
# 索引: str list tuple
# 直接: set ,int ,bool
# 键: dict
坑
lst = [1,2]
for i in lst:
lst.append(3)
print(lst) # 死循环
列表删除——从后向前删除
错误事例:
lst = [1,2,3,4]
for i in lst:
lst.pop()
print(lst) # [1,2]
错误事例:
lst = [1,2,3,4]
for i in lst:
lst.pop(0)
print(lst) # [3,4]
错误事例:
lst = [1,2,3,4]
for i in lst:
lst.remove(i)
print(lst) # [2,4]
成功事例:
lst = [1,2,3,4,6]
for i in range(len(lst)):
lst.pop()
print(lst)
lst = [1,2,3,4,6]
for i in range(len(lst)-1,-1,-1):
del lst[i]
print(lst)
lst = [1,2,3,4,6]
for i in range(len(lst)):
del lst[-1]
print(lst)
# 创建一个新的列表,删除旧的列表
lst = [1,2,3,4,5,6]
lst1 = lst.copy()
for i in lst1:
lst.remove(i)
print(lst)
删除字典的坑
字典迭代的时候不能增加不能删除
集合和字典都是迭代的时候不能增加不能删除
dic = dict.fromkeys("12345",1)
dic1 = dic.copy()
for i in dic1:
dic.pop(i)
print(dic) # 报错
dic = dict.fromkeys("12345",1)
print(dic)
for i in dic:
dic[222] = 666
print(dic) # 报错
dic = dict.fromkeys("12345",1)
dic1 = dic.copy()
for i in dic1:
dic.pop(i)
print(dic)
二次编码
密码本:
ascii ——没有中文
gbk ——英文8b 1B 中文16b 2B
unicode ——英文16b 2B 中文 32b 4B
utf-8 —— 英文8b 1B 欧洲16b 2B 亚洲24b 3B
# name = "你好啊"
# s1 = name.encode("utf-8") # 编码 9
# s2 = name.encode("gbk") # 编码 6
# s2 = s1.decode("utf-8") # 解码
# print(s2.encode("gbk"))
以什么编码集(密码本)进行编码就要用是什么编码集(密码本)解码
day07——数据类型补充、坑、二次编码的更多相关文章
- python基础知识(七)---数据类型补充、"雷区"、编码
数据类型补充."雷区".编码 1.数据类型补充 str: #字符串数据类型补充 s1=str(123) #常用于类型转换 print(s1) #capitalize()首字母大写 ...
- day07数据类型的相互转化,字符编码
复习 ''' 1.深浅拷贝 ls = [1, 'a', [10]] 值拷贝:直接赋值 ls1 = ls, ls中的任何值发生改变,ls1中的值都会随之改变 浅拷贝:通过copy()方法 ls2 = l ...
- [二次编码,数据类型补充以及各种坑]https://i.cnblogs.com/EditPosts.aspx?postid=11184330
数据类型补充 str:不可变数据类型 1.capitalize首字母大写 name="song" n=name.capitalize() print(n) Song 2.title ...
- 326 集合 ,数据类型的补充 ,copy , 编码之间的转换
一.数据类型补充1,对于元组:如果只有一个元素,并且没有逗号,此元素是什么数据类型,改表达式就是什么数据类型. tu = () tu1 = (,) print(tu,type(tu)) #1 < ...
- Mysql学习笔记(二)数据类型 补充
原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...
- python之数据类型补充、集合、深浅copy
一.内容回顾 代码块: 一个函数,一个模块,一个类,一个文件,交互模式下,每一行就是一个代码块. is == id id()查询对象的内存地址 == 比较的是两边的数值. is 比较的是两边的内存地址 ...
- day8数据类型补充,集合,深浅拷贝
思维导图: 集合的补充:下面的思维导图有一个点搞错了,在这里纠正一下,没有合集,是反交集,^这个是反差集的意思 . 交集&,反交集^,差集-,并集|,然后就是子集和超集 数据类型补充: ''' ...
- 巨蟒python全栈开发-第7天 基本数据类型补充&深浅拷贝
1.基本数据类型补充 2.深浅拷贝 DAY7-基本数据类型(基本数据类型补充&深浅拷贝) 本节主要内容: 1.补充基础数据类型 (1)join方法 (2)split方法 (3)列表不能在循环时 ...
- Day7--Python--基础数据类型补充,集合,深浅拷贝
一.基础数据类型补充 1.join() 把列表中的每一项(必须是字符串)用字符串拼接 与split()相反 lst = ["汪峰", "吴君如", " ...
随机推荐
- 异常STATUS_FATAL_USER_CALLBACK_EXCEPTION(0xc000041d)
简介 STATUS_FATAL_USER_CALLBACK_EXCEPTION,值为0xc000041d.代表的意思是"回调期间遇到未处理的异常".它定义在 ntstatus.h头 ...
- 使用plotly dash-component-boilerplate 生成自己的组件
plotly 基于dash-component-boilerplate给我们提供了可以快速生成基于使用python 调用的react 组件 以下是一个简单的使用脚手架生成一个组件,同时可以了解组件的工 ...
- Android 系统Action大全
常用Action说明: String ADD_SHORTCUT_ACTION 动作:在系统中添加一个快捷方式.. “android.intent.action.ADD_SHORTCUT” String ...
- [RN] React Native 使用精美图标库react-native-vector-icons
React Native 使用精美图标库react-native-vector-icons 一.安装依赖 npm install --save react-native-vector-icons // ...
- Problem 1 珠江夜游 (cruise .cpp)———2019.10.6
Problem 1 珠江夜游 (cruise.cpp)[题目描述]小 Z 放假后难得来一趟广州游玩,当然要吃遍广州各路美食小吃然后再到珠江新城看看远近闻名的小蛮腰啦!可当小 Z 一路吃吃吃以后,天渐渐 ...
- JavaScript base64 加密解密
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- MP实战系列(十九)之批量新增
批量操作在实际开发中也应用非常多,例如批量下发优惠券.批量添加用户等. 以MyBatis为例,通常实现批量操作,有这么几种方式? 第一,单条插入sql语句,进行for循环遍历,基准条件是根据前端传过的 ...
- 五种IO模型
参考文档 https://www.jianshu.com/p/486b0965c296 概念说明 用户空间和内核空间 现在操作系统都是采用虚拟存储器,那么对32位操作系统而言,它的寻址空 ...
- 第08组 Beta冲刺(2/4)
队名 八组评分了吗 组长博客链接(2分) 组员1李昕晖(组长) 过去两天完成了哪些任务 文字/口头描述 12月9号了解各个小组的进度与难以攻破的地方,晚上安排开会,安排新的冲刺任务. 重新分配小组及个 ...
- java 把 PEM 格式的公钥证书转换为 X.509 格式的证书
代码: @UtilityClass public final class X509Certs { private static final CertificateFactory CERTIFICATE ...