PythonDay07
第七章
今日内容
基础数据类型补充
以后会遇到的坑
二次编码
基础类型补充
str
a = "One two"
print(a.capitalize()) # 首字母大写
print(a.title()) # 每个单词首字母大写
print(a.swapcase()) # 大小写转换
print(a.center(20,"=")) # 居中 - 填充
print(a.find("c")) # 查找 通过元素查找索引,查找不到时返回-1
print(a.index("c")) # 查找 通过元素查找索引,查找不到时就报错
print("_".join(["1","2","4"])) # 拼接,将列表转换成字符串
str + str
str * 5
#字符串进行加操作,乘操作都是开辟新的空间
list
# 列表的一种定义方法
print(list('123445'))
# 列表的方法:
lst = [1,23,4,5,7,8,9]
print(lst.index(4)) # 通过元素查找索引
lst.sort() # 排序 默认是升序
lst.sort(reverse=True) # 降序
lst.reverse() #将源数据进行反转
print(lst)
lst = [1,5,7,9,4,23,546,78]
lst1 = lst[::-1] #不修改源数据进行反转
dict
dic = {"key":1,"key1":2,"key2":4,"key3":1}
print(dic.popitem()) # 随机删除 python3.6版删除最后一个键值对
#popitem返回的是被删除的键值对
print(dic)
dic = {}
dic = dic.fromkeys("abc",[])
print(dic)
dic["b"] = 11
dic["a"].append(10)
print(dic)
运行结果:
{'a': [], 'b': [], 'c': []}
{'a': [10], 'b': 11, 'c': [10]}
fromkeys 第一个参数必须是可迭代对象,会将可迭代对象进行迭代,成为字典的键.第二个参数是值(这个值是共用的)
fromkeys 共用的值是可变数据类型就会有坑,不可变数据类型就没事
基础数据类型总结:
可变,不可变,有序,无序
1.可变:
list
dict
set
2.不可变:
int
str
bool
tuple
3.有序:
list
tuple
str
4.无序:
dict
set
取值方式:
1.索引
list
tuple
str
2.键
dict
3.直接
int
bool
set
数据类型转换
str -- int
int -- str
str -- bool
bool -- str
int -- bool
bool -- int
重要: *****
list -- str
lst = ["1","2","3"]
print("".join(lst))
str -- list
s = "alex wusir 太白"
print(s.split())
目前字典转换,自己实现方法
重点
重点:
find
join
列表乘法
元组(1,)
list -- str
str -- list
以后会遇到的坑
死循环
lst = [1,2,3]
for i in lst:
lst.append(4)
用for循环删除所有元素
# 错误示范
lst = [11,22,33,44]
for i in lst:
lst.remove(i)
print(lst) # 正确代码
lst = [11,22,33,44]
for i in range(len(lst)):
del lst[-1]
print(lst) for i in range(len(lst)):
lst.pop()
print(lst) # 创建一个浅拷贝的列表,循环它的次数,删除源数据的数据
lst = [11,22,33,44]
lst1 = lst[:]
for i in lst1:
lst.remove(i)
print(lst)
使用for循环清空列表元素内容 1.从后向前删除, 2.创建一个新的容器,循环新的容器删除旧的容器内容
面试题:
lst = [1,[2]]
lst[1] = lst
print(lst) 答案: [1, [...]]
字典和集合
dic = {"key":1,"key1":2}
for i in dic:
if i == "key1":
dic[i] = dic[i] + 8 # dic[i] = 10
else:
print("没有这个键!")
print(dic)
字典和集合在遍历(循环)时不能修改原来的大小(字典的长度),可以进行修改值
# 以下会报错
s = {1,2,3,4,5,6}
for i in s:
s.pop()
print(s)
Set changed size during iteration
二次编码
必会
# python3: 默认编码unicode
# pyhton2:默认编码ascii,不支持中文
以后会遇到的坑
二次编码
PythonDay07的更多相关文章
- Python--day07(数据类型转换、字符编码)
昨天内容回顾 1. 深浅拷贝: 值拷贝:直接赋值,原列表中任何值发生改变,新列表的值都会发生改变. 浅拷贝:通过copy()方法,原列表中存放值的地址没有发生改变,但内部的值发生改变,新列表也随之改 ...
随机推荐
- node.js入门学习(一)环境安装,REPL,fs模块,path模块,http模块
一.node.js介绍 1.1.node.js是什么 官网首页总结:Node.js® 是一个基于 Chrome V8 引擎 的 JavaScript 运行时. 1)node.js是一个开发平台,就像j ...
- 牛客网 Chess ( 博弈 && 奇异局势 )
题目链接 分析 : 发现如果一开始就在边界或者位于对角线的位置上肯定是必胜态 从终点逆推,画出胜负表格,填一填,就会发现和奇异局势的前几项一样 然后打个奇异局势的表就能 AC 了 #include&l ...
- windows10 gcc编译C程序(简单编译)
参考:http://c.biancheng.net/view/660.html gcc可以一次性完成C语言源程序的编译,也可以分步骤完成:下面先介绍一次性编译过程. 1.生成可执行程序 cd xxx ...
- 南京网络赛C
分段打表大法好!!! 打表40min,A题1s https://nanti.jisuanke.com/t/41300 #include<bits/stdc++.h> #define int ...
- [CSP-S模拟测试]:简单计算(数学)
题目传送门(内部题104) 输入格式 第一行一个正整数$T$,表示该测试点内的数据组数,你需要对该测试点内的$T$组数据都分别给出正确的答案才能获得该测试点的分数. 接下来$T$组数据,每组数据一行两 ...
- HDU6025 Coprime Sequence(gcd)
HDU6025 Coprime Sequence 处理出数列的 \(gcd\) 前缀和后缀,删除一个数后的 \(gcd\) 为其前缀和后缀的 \(gcd\) . 遍历数列取 \(max\) 即为答案. ...
- java应用cpu使用率过高问题排查
---------------------------------------linux下如何定位代码问题------------------------------- 1.先通过top命令找到消耗c ...
- learning webrtc 使用node.js
第二章 有使用node.js创建静态服务器的步骤 不过不够详细 下面以Windows为例 1.到官方网站下载安装包 然后安装 2.用管理员权限启动命令行 3.命令行窗口执行npm config set ...
- Python深度学习读书笔记-6.二分类问题
电影评论分类:二分类问题 加载 IMDB 数据集 from keras.datasets import imdb (train_data, train_labels), (test_data, t ...
- Text Classification
Text Classification For purpose of word embedding extrinsic evaluation, especially downstream task. ...