第七章

今日内容

  • 基础数据类型补充

  • 以后会遇到的坑

  • 二次编码

基础类型补充

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的更多相关文章

  1. Python--day07(数据类型转换、字符编码)

    昨天内容回顾 1.  深浅拷贝: 值拷贝:直接赋值,原列表中任何值发生改变,新列表的值都会发生改变. 浅拷贝:通过copy()方法,原列表中存放值的地址没有发生改变,但内部的值发生改变,新列表也随之改 ...

随机推荐

  1. node.js入门学习(一)环境安装,REPL,fs模块,path模块,http模块

    一.node.js介绍 1.1.node.js是什么 官网首页总结:Node.js® 是一个基于 Chrome V8 引擎 的 JavaScript 运行时. 1)node.js是一个开发平台,就像j ...

  2. 牛客网 Chess ( 博弈 && 奇异局势 )

    题目链接 分析 : 发现如果一开始就在边界或者位于对角线的位置上肯定是必胜态 从终点逆推,画出胜负表格,填一填,就会发现和奇异局势的前几项一样 然后打个奇异局势的表就能 AC 了 #include&l ...

  3. windows10 gcc编译C程序(简单编译)

    参考:http://c.biancheng.net/view/660.html gcc可以一次性完成C语言源程序的编译,也可以分步骤完成:下面先介绍一次性编译过程. 1.生成可执行程序 cd xxx ...

  4. 南京网络赛C

    分段打表大法好!!! 打表40min,A题1s https://nanti.jisuanke.com/t/41300 #include<bits/stdc++.h> #define int ...

  5. [CSP-S模拟测试]:简单计算(数学)

    题目传送门(内部题104) 输入格式 第一行一个正整数$T$,表示该测试点内的数据组数,你需要对该测试点内的$T$组数据都分别给出正确的答案才能获得该测试点的分数. 接下来$T$组数据,每组数据一行两 ...

  6. HDU6025 Coprime Sequence(gcd)

    HDU6025 Coprime Sequence 处理出数列的 \(gcd\) 前缀和后缀,删除一个数后的 \(gcd\) 为其前缀和后缀的 \(gcd\) . 遍历数列取 \(max\) 即为答案. ...

  7. java应用cpu使用率过高问题排查

    ---------------------------------------linux下如何定位代码问题------------------------------- 1.先通过top命令找到消耗c ...

  8. learning webrtc 使用node.js

    第二章 有使用node.js创建静态服务器的步骤 不过不够详细 下面以Windows为例 1.到官方网站下载安装包 然后安装 2.用管理员权限启动命令行 3.命令行窗口执行npm config set ...

  9. Python深度学习读书笔记-6.二分类问题

    电影评论分类:二分类问题   加载 IMDB 数据集 from keras.datasets import imdb (train_data, train_labels), (test_data, t ...

  10. Text Classification

    Text Classification For purpose of word embedding extrinsic evaluation, especially downstream task. ...