又学习新东西了,赶紧记下来。
一、 python学习之对文件的读写操作
1-1 对文件的操作顺序:
1 变量 = open(...)
2 操作文件的读写
3 关闭文件
1-2 打开文件的模式
r,只读模式(默认)。
input = open(‘data‘, ‘r‘) 也可写成 input = open(‘data‘)
w,只写模式。(不可读;不存在则创建;存在则删除内容;)
a,追加模式。(可读; 不存在则创建;存在则只追加内容;)
"+" 表示可以同时读写某个文件:
r+,可读写文件。(可读;可写;可追加)
w+,写读
a+,同a
"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用):
rU:input = open(‘data‘, ‘rU‘)
r+U
"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注)
rb
wb
ab
1-3 用with 操作文件自带close()功能,所以不用再写一次close()了,也不用担心会忘记关闭文件。
with
open
(
‘file‘
,
‘r‘
) as f:
......
二、python学习之编码
2-1 编码介绍
ASCII编码:是一种单字节的编码,是对英语字符和二进制之间的关系做的统一规定;
GBK编码:是汉字编码标准之一,使用了双字节编码;
Unicode编码:这是一种世界上所有字符的编码。当然了它没有规定的存储方式;
UTF-8编码: UTF-8 是 Unicode 的一种实现方式。它是可变长的编码方式,可以使用 1~4 个字节表示一个字符,可根据不同的符号而变化字节长度。
2-2 编码之间的转化
GBK转化为UTF-8的过程:
1 首先通过编码(decode)转换为Unicode编码
2 然后通过解码(encode)转换为UTF-8的编码
UTF-8 转化为GBK的过程:
1 首先通过编码(decode)转换为Unicode编码
2 然后通过解码(encode)转换为GBK的编码
三、python学习之函数
3-1 函数是可以实现一些特定功能的小方法或是小程序,他的意义在于
- 减少重复代码
- 增加程序的扩展性
- 维护程序方面
3-2 语法
#不带参函数名
def printdata():
print("Hello")
printdata() #调用函数
#带参数的函数:
def sum(x,y):
z = x+y
return z #返回函数执行结果
c = sum(a,b) #结果赋值给c变量
print(c)
3-3 函数参数与局部变量
形参变量:只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只在函数内部有效。函数调用结束返回主调用函数后则不能再使用该形参变量
实参变量:可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使参数获得确定值
#带参数的函数:
def sum(x,y): --->,x,y为形参
z = x+y
return z #返回函数执行结果,return表示函数的结束;如果未在函数中指定return,那这个函数的返回值为None
c = sum(a,b) -->a,,b为实参
print(c)
3-4 默认参数
def sum(name,country,age):
print("姓名:",name)
print("age:",age)
print("国籍:",country)
将country改为默认参数“CN”:
def sum(name,age,country=‘CN’): #country变成了关键参数,放在位置参数之后
print("姓名:",name)
print("age:",age)
print("国籍:",country)
sum(name=‘alex‘,age=22,) #调用时,不用写country的值
3-5 非固定参数
3-5-1 函数在定义时不确定用户想传入多少个参数,就可以使用非固定参数 *
def stu_register(name,age,*args): # *args 会把多传入的参数变成一个元组形式
print(name,age,args)
3-5-2 **kwargs:会把多传入的参数变成一个dict形式
def sum(name,*args,**kwargs):
print(name,args,kwargs)
sum("Alex",22)
#输出
#Alex () {}#后面这个{}就是kwargs,只是因为没传值,所以为空
sum("lilei","CN","Python",sex="Male",province="ShanDong")
#输出
# lilei (‘CN‘, ‘Python‘) {‘province‘: ‘ShanDong‘, ‘sex‘: ‘Male‘}
3-6 全局与局部变量
在子程序中定义的变量称为局部变量,在程序的一开始定义的变量称为全局变量。
作用域不同:全局变量作用域是整个程序,局部变量作用域是定义该变量的子程序。
当全局变量与局部变量同名时:在定义局部变量的子程序内,局部变量起作用;在其它地方全局变量起作用。
3-7 递归函数
递归函数就是在内部调用自身本身。
递归特性:
1. 必须有一个明确的结束条件
2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少
3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)。
3-8 匿名函数lambda
匿名函数一般与其他函数搭配使用
#这段代码
def sum(x):
return x*x
print(calc(10))
#换成匿名函数
sum = lambda x:x*x
print(sum(10))
搭配使用:
res = map(lambda x:x*2,[1,5,7,4,8])
for i in res:
print(i)
四、python学习之函数式编程介绍
函数式编程使用一系列的函数解决问题。函数仅接受输入并产生输出,不包含任何能影响产生输出的内部状态。任何情况下,使用相同的参数调用函数始终能产生同样的结果。
函数式编程的一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数!
五、python学习之高阶函数
变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。
def f(x):
return x**x
def sum(x,y,f):
return f(x) + f(y)
#调用
sum(2,3,f)
输出:
35 #2**2+3**3=35
六、python学习之内置函数
内置函数,一般都是因为使用频率比较频繁或是是元操作,所以通过内置函数的形式提供出来,这类函数不用自己定义,可直接使用。
例如:abs()、id()