day03 set集合,文件操作,字符编码以及函数式编程
嗯哼,第三天了
我们来get 下新技能,集合,个人认为集合就是用来list 比较的,就是把list 转换为set 然后做一些列表的比较啊求差值啊什么的。
先看怎么生成集合:
list_s = [1,3,4,5,7,9]
list_t = [1,3,4,5,7,9]
dic_1 = {
'name':'shenyang',
'age':16
}
dic_2 = {'name':'wanglu',
'age':18,
'sex':'girl'} s = set(list_s)
t = set(list_t)
d = set(dic_1)
n = set(dic_2)
print(s,type(s))
print(t,type(t))
print(d,type(d))
print(n,type(n))

找并集:
检查是否是子集
#对称差集 把交集去掉,留两边互相都没有的
检查两个set 是否有交集,有返回False 没有返回True
使用运算符 来测试关系:
添加:
#!/usr/bin/env python3
s = set([1,3,4,5,7,9])
t = set([2,3,4,6,8,10])
#交集
print(s & t)
#并集
print(s | t)
#差集 有顺序,找出前面有的后面没有的
print(s - t)
#对称差集
print(s ^ t) #往集合里添加
s.add(10) #添加一项
print(s)
s.update([13,14,15]) #添加多项
print(s)
#删除
s.pop() #随机删除
print(s)
s.remove(13) #删除指定项
print(s) #成员测试
if 14 in s:
print("is in")
if 13 not in s:
print("is not in")
实验:
1 写:
file1 = open("music.lrc","r",encoding="utf-8")
r_file1 = file1.read()
print(r_file1)
file1.close()
2 读:
file1 = open("music.lrc","r",encoding="utf-8")
r_file1 = file1.read()
print(r_file1)
file1.close()
3 追加: 并不能读
file1 = open("music.lrc","a",encoding="utf-8")
file1.write("This is the last write")
file1 = open("music.lrc","r",encoding="utf-8")
r_file1 = file1.read()
print(r_file1)
file1.close()
一行一行读:
判断行号,只能自己加一个计数器 高逼格的办法
句柄指针: 是按字符计算的
打印文件的字符编码:


修改文件:

实践:
#!/usr/bin/env python3
# Auth: Shen Yang
f1 = open("lrc.db","r",encoding="utf-8")
f2 = open("lrc2.db","w",encoding="utf-8")
for line in f1:
if "王山炮" in line:
line = line.replace("王山炮","Alex")
f2.write(line)
f1.close()
f2.close()

pyhton 3 默认所有的数据类型就是Unicode 你哈 还是 utf-8 除非你转到gbk 上面的只是说这个文件的编码
python 3 中 encode 不但转换了编码还变成了bytes 格式的

过程就是没有返回值的函数 但是在python 中 隐式的给过程一个结果
练习:
import time
def logger():
time_format = '%T-%m-%d %X'
time_current = time.strftime(time_format)
with open("fun.log","a+",encoding="utf-8") as f:
f.write("{_format} aadd the log\n".format(_format=time_current))
time.sleep(0.5)
def test1():
print("This is test1")
logger()
def test2():
print("This is test2")
logger()
def test3():
print("This is test3")
logger()
test1()
test2()
test3()
默认参数特点:
传递非固定实参的时候形参使用以* 开头的任意字符即可但不要这样写,就写args :
以字典的方式保存参数
默认参数一定要放在** 的前面
name = "yang"
Job = "Pyther"
def change_name(name="Lu"):
#global Job
Job = "Shell" print("name:",name,Job) change_name(name="Wang")
print(name,Job)
def calc(n):
prin(n)
return calc(n)
最简单的递归:
#!/usr/bin/env python3
# Auth: Shen Yang
def calc(n):
print(n)
if int(n/2) >0:
return calc(int(n/2))
print("This is >>",n)
calc(10)
def add(a,b,f):
return f(a) + f(b)
res = add(3,-6,abs)
print(res)
day03 set集合,文件操作,字符编码以及函数式编程的更多相关文章
- python基础之 列表、元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...
- python学习笔记(2)--列表、元组、字符串、字典、集合、文件、字符编码
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1.列表和元组的操作 列表是我们以后最长用的数据类型之一,通过列表可以最方便的对数据实现最方便的存储.修改等操作 定 ...
- Day2 - Python基础2 列表、字符串、字典、集合、文件、字符编码
本节内容 列表.元组操作 数字操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 ...
- Python基础2 列表 元祖 字符串 字典 集合 文件操作 -DAY2
本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...
- linux下改变文件的字符编码
首先确定文件的原始字符编码: $ file -bi test.txt 然后用 iconv 转换字符编码 $ iconv -f from-encoding -t to-encoding file > ...
- Gnu Linux下文件的字符编码及转换工具
/********************************************************************* * Author : Samson * Date ...
- eclipse设置新建jsp文件默认字符编码为utf-8
在使用Eclipse开发中,编码默认是ISO-8859-1,不支持中文.这样我们每次新建文件都要手动修改编码,非常麻烦.其实我们可以设置文件默认编码,今后再新建文件时就不用修改编码了. 1.打开Ecl ...
- python3笔记十八:python列表元组字典集合文件操作
一:学习内容 列表元组字典集合文件操作 二:列表元组字典集合文件操作 代码: import pickle #数据持久性模块 #封装的方法def OptionData(data,path): # ...
- Python基础-week03 集合 , 文件操作 和 函数详解
一.集合及其运算 1.集合的概念 集合是一个无序的,不重复的数据组合,它的主要作用如下 *去重,把一个列表变成集合,就自动去重了 *关系测试,测试两组数据之前的交集.并集.差集.子集.父级.对称差集, ...
随机推荐
- 3.Freshman阶段学习内容的确定
我刷知乎.在知乎上答题的程序员,不是很牛逼就是更牛逼,说起各种系统.各种系统的各种版本.各种语言.数据库.算法.IT届的各种圣战都有板有眼.信手拈来.头头是道,不得不服.这导致了一些非常严重的问题:我 ...
- jeecg308自定义使用getDataGridReturn方法分页失效问题
DataGrid dataGrid = new DataGrid(); dataGrid.setPage(p); dataGrid.setRows(r); dataGrid.setOrder(&quo ...
- spring boot Filter过滤器的简单使用
springboot使用Filter过滤器有两种方式: 一种是实现Filter接口然后通过@Component注解向项目加入过滤器 另一种是通过配置类来配置过滤器 @Component public ...
- 从照片网站pexels批量爬取照片
调试中,未成功. from bs4 import BeautifulSoup import requests headers={ #'User-Agent':'Nokia6600/1.0 (3.42. ...
- python整体图
- Nodejs:npm run build之后,dist\index.html页面在火狐中可以正常显示登录页面并登录成功,在Chrome中可以正常显示登录页面,登录失败
问题描述:Nodejs:npm run build之后,dist\index.html页面在火狐中可以正常显示登录页面并登录成功,在Chrome中可以正常显示登录页面,登录失败 解决方法:将打包后的d ...
- oracle 命中率
一般在I/O 使用中,为了提高系统处理速度,系统提前将数据读入一块内存区,叫高速缓存,但提前读入的数据未必就是需要的,这就是命中率..计算公式为 命中率=1-(physical reads/(db b ...
- Electron的介绍
1.1 Electron是什么? 引用官网的一句话: Build cross platform desktop apps with JavaScript, HTML, and CSS 1.2 诞生 技 ...
- pandas的数据联级
一.索引的堆(stack) 1.行列的转化: Stack():列转行 Unstack():行转列 Stack对应行, 使用小技巧:使用stack()的时候,level等于哪一个,哪一个就消失,出现在行 ...
- 201621123080《Java程序设计》第三周学习总结
Week03-面向对象入门 1. 本周学习总结 2. 书面作业 1.以面向对象方式改造数据结构作业'有理数'(重点) 1.1 截图你主要代码(需要在程序中出现你的学号和姓名)并粘贴程序的git地址. ...