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 = ["汪峰", "吴君如", " ...
随机推荐
- tab吸顶的神奇-- css粘性属性
position: -webkit-sticky; position: sticky; top: 0.86rem; //可以自定义设置大小 亲测,目前谷歌浏览器等都已经支持该属性.
- 5-微信小程序开发(小程序页面跳转和布局说明)
https://www.cnblogs.com/yangfengwu/p/11605209.html 新建一个小程序 咱现在新建个页面 在pages 上右击,选择新建目录 会自动添加这几个文件 现在做 ...
- 05-树8 File Transfer (25 分)
We have a network of computers and a list of bi-directional connections. Each of these connections a ...
- [后渗透]Windows server 80端口复用后门
0x01 简介 该后门的基本原理是使用Windows 的远程管理管理服务WinRM,组合HTTP.sys驱动自带的端口复用功能,一起实现正向的端口复用后门. 具体细节信息请参考:https://pap ...
- 安装和启动ElasticSearch服务遇到的几个问题
首先安装和启动服务的教程是参考文章:ES入门之一 安装ElasticSearch 然后在最后的启动es服务时遇到了几个小问题,因此在这里记录一下. 因为我对linux并不是很熟悉,因此文中如果有说错的 ...
- quick: setup_mac.sh分析
//quick: setup_mac.sh分析 //quick: setup_mac.sh分析#!/bin/bash //获取并打印根目录QUICK_V3_ROOTDIR="$( cd &q ...
- 必会的 55 个 Java 性能优化细节!一网打尽!
阅读本文大概需要 10 分钟. 来源:https://yq.aliyun.com/articles/662001 在 Java 程序中,性能问题的大部分原因并不在于 Java 语言,而是程序本身.养成 ...
- NIOBuffer 缓冲区
Java NIO 由以下几个核心部分组成: Channels Buffers Selectors 虽然Java NIO 中除此之外还有很多类和组件,但是,Channel,Buffer 和 Select ...
- 写一个eggjs权限验证中间件
关于中间件 https://eggjs.org/zh-cn/basics/middleware.html 官方文档说的很清楚了,不再叙述. 我们要达到怎么样一个效果? 用户没有登录不能访问一些特定的页 ...
- Asp.Net Core Cookie使用,Asp.net Core Cookie操作失效
注:本文主要介绍Asp.net Core 3.0后增加cookie代理功能. 默认是增加了的. 默认增加的这个有些问题所在, 1.原来设置cookie方式将不可用,需要按照代理方式设置 2.对于ses ...