本节内容

1.集合操作

2.文件操作

3.字符编码与转码

4.函数

====================================

一、集合操作

集合是一个无序的,不重复的数据组合,它的主要作用如下:

  • 去重,把一个列表变成集合,就自动去重了
  • 关系测试,测试两组数据之前的交集、差集、并集等关系

1.1定义一个集合

 a = set((,,))
print(a)

输出:

 {, , }
 list_1 = [,,,,]
list_2 =set(list_1)
print(list_1) 输出:
[, , , , ]

2.关系测试

交集(取重)

a = set([1,2,3,4,5])
b = set([3,5])
方法一:
t = a & b
print(t)
方法二:
s = a.intersection(b)
print(s) 输出结果:
{3, 5}
{3, 5}

并集(去重)

 1 a = set([1,2,3,4,5])
2 b = set([3,5,7,9,10])
3 方法一:
4 t = a | b
5 print(t)
6 方法二:
7 s = a.union(b)
8 print(s)
9 输出结果:
10 {1, 2, 3, 4, 5, 7, 9, 10}
11 {1, 2, 3, 4, 5, 7, 9, 10}

差集

a = set([1,2,3,4,5])
b = set([3,5,7,9,10])
方法一:
t = a - b
t2 = b - a
print(t)
print(t2) 方法二:
s = a.difference(b)
s2 = b.difference(a)
print(s)
print(s2)
==================
输出结果:
{1, 2, 4}
{9, 10, 7}
{1, 2, 4}
{9, 10, 7}

子集&父级

a = set([3,5,7])
b = set([1,2,3,4,5,6,7,8])
print(a.issubset(b)) #a是b的子集
print(b.issuperset(a)) #b是a的父集 输出结果:
True
True

对称差集

a = set([3,5,7])
b = set([1,2,3,4,5,6,7,8])
#二种方法
print(a ^ b)
print(a.symmetric_difference(b)
================
输出结果: {1, 2, 4, 6, 8}
{1, 2, 4, 6, 8}

二、文件操作 

对文件操作流程

  1. 打开文件,得到文件句柄并赋值给一个变量
  2. 通过句柄对文件进行操作
  3. 关闭文件

基础操作

 f = open('lyrics') #打开文件

 first_line = f.readline()

 print('first line:',first_line) #读一行

 print('我是分隔线'.center(50,'-'))

 data = f.read()# 读取剩下的所有内容,文件大时不要用

 print(data) #打印文件

 f.close() #关闭文件

打开文件模式有:

  • r,只读模式(默认)。
  • w,只写模式。【不可读;不存在则创建;存在则删除内容;】
  • a,追加模式。【可读;   不存在则创建;存在则只追加内容;】

"+" 表示可以同时读写某个文件

  • r+,可读写文件。【可读;可写;可追加】
  • w+,写读
  • a+,同a

"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)

  • rU
  • r+U

"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)

  • rb
  • wb
  • ab

现有文件如下:

 Oh, yesterday when I was young

 噢 昨日当我年少轻狂

 So many, many songs were waiting to be sung

 有那么那么多甜美的曲儿等我歌唱

 So many wild pleasures lay in store for me

 有那么多肆意的快乐等我享受

 And so much pain my eyes refused to see

 还有那么多痛苦 我的双眼却视而不见

 There are so many songs in me that won't be sung

 我有太多歌曲永远不会被唱起

 I feel the bitter taste of tears upon my tongue

 我尝到了舌尖泪水的苦涩滋味

 The time has come for me to pay for yesterday

 终于到了付出代价的时间 为了昨日

 When I was young

 当我年少轻狂

f = open('test,txt','r')  文件句柄

f = f.readlines()  #将文件全部读出,以列表方式

文件重命名

==============================

import os
os.remove('test.txt')                   #先将原文件删除,否则无法重命名
os.rename('test1.txt','test.txt')       #将新文件重命名为原文件名

==============================
例:文件里面内容替换

import  os
print("文件内容如下:")
with open('test.txt','r',encoding="utf-8") as f: #只读模式打开文件
for i in f:
print(i) #将原文件内容打印出来,方便查看需要替换的内容
s = input("请输入你要替换前的内容:")
s2 = input("请输入要替换后的内容:")
f = open('test.txt','r',encoding="utf-8")
with open('test1.txt','w+',encoding="utf-8") as p: #以写读模式重新打开文件
for j in f: #循环文件
if s in j: #判断要替换的内容是否存在于文件中
j = j.replace(s,s2) #替换需要替换的内容
p.write(j) #将内容重新写入到文件
f.flush() #刷新缓存到硬盘
f.close() #关闭文件
os.remove('test.txt') #先将原文件删除,否则无法重命名
os.rename('test1.txt','test.txt') #将新文件重命名为原文件名

with语句

为了避免打开文件后忘记关闭,可以通过管理上下文,即:

with open('log','r') as f:

pass

如此方式,当with代码块执行完毕时,内部会自动关闭并释放文件资源。

在Python 2.7 后,with又支持同时对多个文件的上下文进行管理,即:

with open('log1') as obj1, open('log2') as obj2:

pass

三、函数

  1.面向对象

  2.面向过程   #没有返回值

  3.函数式编程  #有返回值(有返回值的面向过程)

1.函数定义

    python中函数定义方法:

    def test():
"The function definitions"
return 0 #返回值,遇到return就终止运行了
print (‘123) #后面的print就不执行了
x = test() #将返回值赋值给x

例一:打印带时间的日志到文件

 import time
def logger_test():
time_format='%Y-%m-%d %X'
time_current=time.strftime(time_format)
with open('a.txt','a+) as f:
f.write('time %s end action' %time_current)
def test1():
print 'test1 starting action...' logger_test() def test2():
print 'test2 starting action...' logger_test() def test3():
print 'test3 starting action...'

2、参数

  1. 位置参数

def test(x,y):         #x,y位置参数,下面传参的时候要一一对应,不可多,也不可少
print(x)
print(y)
test(1,2) #1,2实际存在于内存中,是实参,x和y为形参

  2.关键参数

def test(x,y,z):
print(x)
print(y)
print(z)
test(z=1,x=2,y=3) #x,y,z为关键参数,不用一一对应

  例:

def test(x,y,z):
print(x)
print(y)
print(z)
test(1,2,z=3) #1,2是位置参数,z=3是关键参数,关键参数只能放置在位置参数后面

  3.默认参数

def test(x,y=2):        #y = 2是默认参数
print(x)
print(y)
test(1) #y有默认参数,所以可以不用传参
test(1,3) #实际参数大于默认参数
test(1,y=4) #大于默认参数

  4.参数组

def test(*alex)     #alex是形参
print(alex)
def test1(x,*args) #规范就是args,*args接受位置参数,转换成元组的方式
print(x)
print(args)
test(1,2,3,4,5) #实参可以任意数量
test1(1,2,3,4,5) #1传给x,2,3,4,5,传给args

**kwargs参数组

把所有关键参数转换成字典,接受关键字参数
def test(**kwargs):
print(kwargs)
test(name = 'lw',age='')
输出:{'age': '', 'name': 'lw'}
----------------------------------------------------
def test2(name,**kwargs):
print(name)
print(kwargs)
test2('lw')
输出:
lw
{}
-------------------------------------------------------
def test3(name,age=10,**kwargs):
print( name)
print(age)
print(kwargs)
test3('lw',sex='M',hobby='tesla')
输出:
lw
10
{'hobby': 'tesla', 'sex': 'M'}
----------------------------------------------------------

四、局部变量

例:

def change_name(name):
print("before change",name)
name = "LW" #局部变量,只在此函数中生效,像列表,字典,集合等可以在全局神效(只有字符串和整数之类的只在函数生效)
print("after change",name)
name = "lw"
change_name(name)
print(name)
输出:
before change lw
after change LW
lw

五、全局变量

school  == ‘oldboy’
def change_name(name):
school = 'MG'
print("before change",school)
change_name('lw')
print(school) 在函数里面定义全局变量:global school = 'MG'
不要在函数里面改(定义)全部变量

六、递归

  在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。

递归特性:

1. 必须有一个明确的结束条件
2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少
3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出

例一、

 def calc(n):
print(n)
if int(n/2)>0:
return calc(int(n/2))
print('--->',n)
calc(20)

python学习之路-day3的更多相关文章

  1. ql的python学习之路-day3

    字典操作 特性: 1.无序的 2.key是唯一的 , ,,], ,,], ,,], }, ,,], 'bbb' : ['a', 'b', 'c'], }}

  2. python学习之路-day2-pyth基础2

    一.        模块初识 Python的强大之处在于他有非常丰富和强大的标准库和第三方库,第三方库存放位置:site-packages sys模块简介 导入模块 import sys 3 sys模 ...

  3. Python学习之路-Day2-Python基础3

    Python学习之路第三天 学习内容: 1.文件操作 2.字符转编码操作 3.函数介绍 4.递归 5.函数式编程 1.文件操作 打印到屏幕 最简单的输出方法是用print语句,你可以给它传递零个或多个 ...

  4. Python学习之路-Day2-Python基础2

    Python学习之路第二天 学习内容: 1.模块初识 2.pyc是什么 3.python数据类型 4.数据运算 5.bytes/str之别 6.列表 7.元组 8.字典 9.字符串常用操作 1.模块初 ...

  5. Python学习之路-Day1-Python基础

    学习python的过程: 在茫茫的编程语言中我选择了python,因为感觉python很强大,能用到很多领域.我自己也学过一些编程语言,比如:C,java,php,html,css等.但是我感觉自己都 ...

  6. python学习之路网络编程篇(第四篇)

    python学习之路网络编程篇(第四篇) 内容待补充

  7. Python学习之路【第一篇】-Python简介和基础入门

    1.Python简介 1.1 Python是什么 相信混迹IT界的很多朋友都知道,Python是近年来最火的一个热点,没有之一.从性质上来讲它和我们熟知的C.java.php等没有什么本质的区别,也是 ...

  8. python 学习之路开始了

    python 学习之路开始了.....记录点点滴滴....

  9. python学习之路,2018.8.9

    python学习之路,2018.8.9, 学习是一个长期坚持的过程,加油吧,少年!

随机推荐

  1. VS2012打开解决方案崩溃或点击项目崩溃

    打开项目文件就VS2012就崩溃 解决方案: 步骤1:开始-->所有程序-->Microsoft Visual Studio 2012-->Visual Studio Tools-- ...

  2. Linux下删除空文件,删除指定大小的文件

    Linux下批量删除空文件(大小等于0的文件)的方法: find . -name "*" -type f -size 0c | xargs -n 1 rm -f 用这个还可以删除指 ...

  3. Mobile Web调试工具Weinre (reproduce)

    Mobile Web调试工具Weinre 现在.将来,用移动设备上网越来越成为主流.但对于开发者们来说,移动web的调试一直是个难题,前期可以使用模拟器来协助调试,但到了真机调试阶段就让人非常头痛.而 ...

  4. sql查询指定范围内的所有月份

    ),) FROM master..spt_values WHERE type='P' AND DATEADD(MONTH,number,'2016-01-01')<='2017-01-01'

  5. springMVC下载FTP上的文件

    springMVC下载FTP上的文件 今天没时间写.先上传 一个工具类 工具类 package com.utils; import java.io.File; import java.io.FileO ...

  6. 10,SFDC 管理员篇 - 流程自动化

    1,Process Builder Setup | Build | Create | Workflow & Approvals | Process Builder 当我们在对象中创建或者修改一 ...

  7. 5,SFDC 管理员篇 - 数据模型 - 数据关联

    1,PickList 1,填写基本信息 2, 选择能角色的权限 3,在哪一个层上显示(object 上有多个 Record Type 对应多个层,需要选择在哪一个层显示) 4,Save   2,两个P ...

  8. 用移动智能设备访问Ossim系统

    用移动智能设备访问Ossim系统 下面我们使用iPad,iPhone访问ossim系统的效果. 高清视频:http://www.tudou.com/programs/view/TikMZ1z1ELw ...

  9. TextView 中添加超链接

    在textView添加超链接,有两种方式,第一种通过HTML格式化你的网址,一种是设置autolink,让系统自动识别超链接,下面为大家介绍下这两种方法的实现   代码如下:    第一种    pu ...

  10. nuint笔记

    注意:单元测试中,Case 与 Case 之间不能有任何关系 测试方法不能有返回值,不能有参数,测试方法必须声明为 public [TestFixture] //声明测试类 [SetUp] //建立, ...