本节内容

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. 黄聪:PHP解决textarea内容换行存入数据库,如何解析取出不能自动换行

    解决办法: <textarea rows="5" style="height: auto;" ><?php //按行分割,然后每行输出后带上一 ...

  2. linux gcc头文件搜索路径

    #include <>: 直接到系统指定的某些目录中去找某些头文件.#include "": 先到源文件所在文件夹去找,然后再到系统指定的某些目录中去找某些头文件 1. ...

  3. LINUX下动态库及版本号控制

    针对同一动态组件的不同版本链接和加载. 一.概念                  DLL HELL字面意思是DLL"灾难",是由于com组件(动态库)升级引起的程序不能运行的情况 ...

  4. python 简单爬虫diy

    简单爬虫直接diy, 复杂的用scrapy import urllib2 import re from bs4 import BeautifulSoap req = urllib2.Request(u ...

  5. (LinkedList)Intersection of Two Linked Lists

    Write a program to find the node at which the intersection of two singly linked lists begins. For ex ...

  6. 【解决】AgentSVN不能输入用户名/密码的问题

    在Microsoft SQL Server Management Studio中使用AgentSVN时,在完成如下图中配置时, 会提示认证失败错误.其原因是没有输入SVN用户和密码.但问题是此界面中没 ...

  7. Java操作SFTP

    import java.util.Properties; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.jcr ...

  8. Install FFMPEG and FFMPEG-PHP in CentOS 6 with Virtualmin

    Install FFMPEG and FFMPEG-PHP in CentOS 6 with Virtualmin  1 year ago -  by Daniel -  howto centos v ...

  9. iOS 获取文件的目录路径的几种方法 [转]

    iOS 获取文件的目录路径的几种方法 2 years ago davidzhang iphone沙箱模型的有四个文件夹,分别是什么,永久数据存储一般放在什么位置,得到模拟器的路径的简单方式是什么. d ...

  10. 异步SRAM控制器的Verilog建模

    前言:sram顾名思义静态随机存储器,分为asram异步型和ssram同步型.这里驱动DE2上一块ISSI公司的512KB的asram. 设计思路:因为实际应用中单字节读写效率不高,所以本设计中仿照s ...