python自学笔记(四)

1、函数

1.1 函数的定义

  python的函数就是已经写好的,用于解决一定问题的程序,可以重复使用。函数能提高应用的模块性,和代码的重复利用率。python提供了许多内建函数,比如print()。也可以自己创建函数,这被叫做用户自定义函数。

以下是定义一个函数的规则

  • 函数代码块以def开头,后接函数名称,然后加();
  • 任何传入参数和自变量必须放在圆括号中间,圆括号之间可以用于定义参数;
  • 任何传入参数和自变量必须放在圆括号中间,圆括号之间可以用于定义参数;
  • 函数内容以冒号起始,并且缩进;
  • return [表达式] 结束函数,选择性地返回一个值给调用方。不带表达式的return相当于返回 None。

语法:

def 函数名(参数列表):
  函数体

默认情况下,参数值和参数名称是按函数声明中定义的顺序匹配起来的。

实例如下:

>>> def  hello():
...     print("hello,world!")
...
>>> hello()
hello,world!
>>> def  area(width,height):
...     return  width*height
...
>>> def print_welcome(name):
...     print("welcome",name)
...
>>> w=2;
>>> h=4;
>>> area(w,h)
8
>>> name='yeye'
>>> print_welcome(name)
welcome yeye

1.2 函数返回值

return[表达式]语句用于退出函数,选择性地向调用方返回一个表达式,不带参数值的return语句返回None。

以下实例演示了return语句的用法:


>>> def  sum(age1,age2):
...     total=age1+age2    #返回两个参数的和
...     print("函数内:",total)
...     return total
...
>>> total=sum(10,20)
函数内: 30
>>> print("函数外:",total)
函数外: 30

1.3 函数关键字

关键字是python内置的,具有特殊意义的标识符,自定义标识符命名时不可与之重复。可通过以下代码查看python内置的关键字内容:

>>>import keyword 
>>>print(keyword.kwlist)
['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']

共33个关键字。

1.4 函数参数

以下是调用函数时可使用的正式参数类型:

  • 必需参数
  • 关键字参数
  • 默认参数
  • 不定长参数

必需参数
必需参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。

比如,调用printme()函数,你必须传入一个参数,不然会出现语法错误:

>>> def  printme(str):
...     "打印任何传入的字符串"
...     print(str)
...     return
...
>>> #调用printme函数
... printme()
Traceback (most recent call last):
  File "<stdin>", line 2, in <module>
TypeError: printme() missing 1 required positional argument: 'str'

关键字参数
关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值

以下实例在函数 printme() 调用时使用参数名:

>>> def  printme(str):
...     "打印任何传入的字符串"
...     print(str)
...     return
...
>>> #调用printme函数
... printme(str="yeyedakeai")
yeyedakeai

以下实例中演示了函数参数的使用不需要使用指定顺序:

>>> def  personal(name,age):
...     "打印任何传入的字符串"
...     print("名字:",name)
...     print("年龄:",age)
...     return
...
>>> #调用personal函数
... personal(age=18,name="yeye")
名字: yeye
年龄: 18

默认参数
调用函数时,如果没有传递参数,则会使用默认参数。以下实例中如果没有传入 age 参数,则使用默认值:


>>> def  personal(name,age=18):
...     "打印任何传入的字符串"
...     print("名字:",name)
...     print("年龄:",age)
...     return
...
>>> #调用persoal函数
... personal(age=20,name='yeye')
名字: yeye
年龄: 20
>>> personal(name='yeye')
名字: yeye
年龄: 18

不定长参数
如果需要一个函数能处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述 2 种参数不同,声明时不会命名。基本语法如下:

def functionname([formal_args,] *var_args_tuple):
  “函数_文档字符串”
  function_suite
  return[expression]

加了星号 * 的参数会以元组(tuple)的形式导入,存放所有未命名的变量参数。


>>> def  personal(arg1,*vartuple):
...     "打印任何传入的数据"
...     print("输出:")
...     print(arg1)
...     print(vartuple)
...
>>> #调用personal函数
... personal(1,2,3,4,5,6)
输出:
1
(2, 3, 4, 5, 6)

如果在函数调用时没有指定参数,它就是一个空元组。我们也可以不向函数传递未命名的变量。如下实例:

>>> def  personal(arg1,*vartuple):
...     "打印任何传入的数据"
...     print("输出:")
...     print(arg1)
...     for var in vartuple:
...         print(var)
...     return
...
>>> personal(1,2,3,4,5,6,7)
输出:
1
2
3
4
5
6
7

还有一种就是参数带两个星号 **, 加了两个星号 ** 的参数会以字典的形式导入。基本语法如下:

def functionname([formal_args,] **var_args_dict ):
   “函数_文档字符串”
   function_suite
   return [expression]

>>> def  personal(arg1,**vardict):
...     "打印任何传入的参数"
...     print("输出:")
...     print(arg1)
...     print(vardict)
...
>>> #调用personal函数
... personal(1,a=2,b=3)
输出:
1
{'a': 2, 'b': 3}

1.5 变量作用域

Python 中,程序的变量并不是在哪个位置都可以访问的,访问权限决定于这个变量是在哪里赋值的。变量的作用域决定了在哪一部分程序可以访问哪个特定的变量名称。Python的作用域一共有4种,分别是:

  • L (Local) 局部作用域
  • E (Enclosing) 闭包函数外的函数中
  • G (Global) 全局作用域
  • B (Built-in) 内置作用域(内置函数所在模块的范围)

以 L –> E –> G –>B 的规则查找,即:在局部找不到,便会去局部外的局部找(例如闭包),再找不到就会去全局找,再者去内置中找。

g_count = 0 # 全局作用域
def outer():
  o_count = 1 # 闭包函数外的函数中
  def inner():
      i_count = 2 # 局部作用域

内置作用域是通过一个名为 builtin 的标准模块来实现的,但是这个变量名自身并没有放入内置作用域内,所以必须导入这个文件才能够使用它。在Python3.0中,可以使用以下的代码来查看到底预定义了哪些变量:

import builtins
dir(builtins)

Python 中只有模块(module),类(class)以及函数(def、lambda)才会引入新的作用域,其它的代码块(如 if/elif/else/、try/except、for/while等)是不会引入新的作用域的,也就是说这些语句内定义的变量,外部也可以访问,如下代码:

>>> if True:
...  msg = 'I am from shannxi'
... 
>>> msg
'I am from shannxi'
>>> 

实例中 msg 变量定义在 if 语句块中,但外部还是可以访问的。如果将 msg 定义在函数中,则它就是局部变量,外部不能访问:

>>> def test():
...     msg_inner = 'I am from shannxi'
... 
>>> msg_inner
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'msg_inner' is not defined
>>> 

从报错的信息上看,说明了 msg_inner 未定义,无法使用,因为它是局部变量,只有在函数内可以使用。
详细的介绍见菜鸟教程

2、文件(file)

2.1 打开文件方式

Python open() 方法用于打开一个文件,并返回文件对象,在对文件进行处理过程都需要使用到这个函数,如果该文件无法被打开,会抛出 OSError。

注意:使用 open() 方法一定要保证关闭文件对象,即调用 close() 方法。open() 函数常用形式是接收两个参数:文件名(file)和模式(mode)。

语法如下:

open(file, mode=‘r’, buffering=-1, encoding=None, errors=None, newline=None, closefd=True, opener=None)

参数说明:

  • file: 必需,文件路径(相对或者绝对路径);
  • mode: 可选,文件打开模式;
  • buffering: 设置缓冲;
  • encoding: 一般使用utf8;
  • errors: 报错级别;
  • newline: 区分换行符;
  • closefd: 传入的file参数类型
  • opener:
    mode参数详情见菜鸟教程

2.2 文件对象的操作方法

file 对象使用 open 函数来创建,下表列出了 file 对象常用的函数:

序号方法及描述
1file.close()----关闭文件。关闭后文件不能再进行读写操作。
2file.flush()----刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。
3file.fileno()----返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。
4file.isatty()----如果文件连接到一个终端设备返回 True,否则返回 False。
5file.next()----Python 3 中的 File 对象不支持 next() 方法。返回文件下一行。
7file.readline([size])----读取整行,包括 “\n” 字符。
8file.readlines([sizeint])----读取所有行并返回列表,若给定sizeint>0,返回总和大约为sizeint字节的行, 实际读取值可能比 sizeint 较大, 因为需要填充缓冲区。
9file.seek(offset[, whence])----设置文件当前位置
10file.tell()----返回文件当前位置。
11file.truncate([size])----从文件的首行首字符开始截断,截断文件为 size 个字符,无 size 表示从当前位置截断;截断之后后面的所有字符被删除,其中 Widnows 系统下的换行代表2个字符大小。
12file.write(str)将字符串写入文件,返回的是写入的字符长度。

2.3 对Excel及CSV文件进行操作

可调用pandas读取文件官方提供的文档.
具体参考:https://www.cnblogs.com/happymeng/p/10481293.html

3、Os模块

os 模块提供了非常丰富的方法用来处理文件和目录。常用的方法如下表所示:

序号方法及描述
1os.access(path, mode)----检验权限模式
2os.chdir(path)----改变当前工作目录
3os.chflags(path, flags)----设置路径的标记为数字标记
4os.chmod(path, mode)----更改权限
5os.chown(path, uid, gid)----更改文件所有者
6os.chroot(path)----改变当前进程的根目录
7os.close(fd)----关闭文件描述符 fd
8os.closerange(fd_low, fd_high)----关闭所有文件描述符,从 fd_low (包含) 到 fd_high (不包含), 错误会忽略
9os.dup(fd)----复制文件描述符 fd
10os.dup2(fd, fd2)----将一个文件描述符 fd 复制到另一个 fd2
11os.fchdir(fd)----通过文件描述符改变当前工作目录
12os.fchmod(fd, mode)----改变一个文件的访问权限,该文件由参数fd指定,参数mode是Unix下的文件访问权限
13os.fchown(fd, uid, gid)----修改一个文件的所有权,这个函数修改一个文件的用户ID和用户组ID,该文件由文件描述符fd指定
14os.fdatasync(fd)----强制将文件写入磁盘,该文件由文件描述符fd指定,但是不强制更新文件的状态信息
15os.fdopen(fd[, mode[, bufsize]])----通过文件描述符 fd 创建一个文件对象,并返回这个文件对象
16os.fpathconf(fd, name)----返回一个打开的文件的系统配置信息。name为检索的系统配置的值,它也许是一个定义系统值的字符串,这些名字在很多标准中指定(POSIX.1, Unix 95, Unix 98, 和其它)
17os.fstat(fd)----返回文件描述符fd的状态,像stat()
18os.fstatvfs(fd)----返回包含文件描述符fd的文件的文件系统的信息,像 statvfs()
19os.fsync(fd)----强制将文件描述符为fd的文件写入硬盘
20os.ftruncate(fd, length)----裁剪文件描述符fd对应的文件, 所以它最大不能超过文件大小
21os.getcwd()----返回当前工作目录
22os.getcwdu()----返回一个当前工作目录的Unicode对象
23os.isatty(fd)----如果文件描述符fd是打开的,同时与tty(-like)设备相连,则返回true, 否则False
24os.lchflags(path, flags)----设置路径的标记为数字标记,类似 chflags(),但是没有软链接
25os.lchmod(path, mode)----修改连接文件权限
26os.lchown(path, uid, gid)----更改文件所有者,类似 chown,但是不追踪链接
27os.link(src, dst)----创建硬链接,名为参数 dst,指向参数 src
28os.listdir(path)----返回path指定的文件夹包含的文件或文件夹的名字的列表
29os.lseek(fd, pos, how)----设置文件描述符 fd当前位置为pos, how方式修改: SEEK_SET 或者 0 设置从文件开始的计算的pos; SEEK_CUR或者 1 则从当前位置计算; os.SEEK_END或者2则从文件尾部开始. 在unix,Windows中有效
31os.major(device)----从原始的设备号中提取设备major号码 (使用stat中的st_dev或者st_rdev field)
32os.makedev(major, minor)----以major和minor设备号组成一个原始设备号
34os.minor(device)----从原始的设备号中提取设备minor号码 (使用stat中的st_dev或者st_rdev field )
35os.mkdir(path[, mode])----以数字mode的mode创建一个名为path的文件夹.默认的 mode 是 0777 (八进制)
36os.mkfifo(path[, mode])----创建命名管道,mode 为数字,默认为 0666 (八进制)
37os.mknod(filename[, mode=0600, device])----创建一个名为filename文件系统节点(文件,设备特别文件或者命名pipe)
38os.open(file, flags[, mode])----打开一个文件,并且设置需要的打开选项,mode参数是可选的
39os.openpty()----打开一个新的伪终端对。返回 pty 和 tty的文件描述符。
41os.pipe()----创建一个管道. 返回一对文件描述符(r, w) 分别为读和写
45os.remove(path)----删除路径为path的文件。如果path 是一个文件夹,将抛出OSError; 查看下面的rmdir()删除一个 directory
46os.removedirs(path)----递归删除目录
47os.rename(src, dst)----重命名文件或目录,从 src 到 dst48os.renames(old, new)递归地对目录进行更名,也可以对文件进行更名
49os.rmdir(path)----删除path指定的空目录,如果目录非空,则抛出一个OSError异常
50os.stat(path)----获取path指定的路径的信息,功能等同于CAPI中的stat()系统调用
51os.stat_float_times([newvalue])----决定stat_result是否以float对象显示时间戳
52os.statvfs(path)----获取指定路径的文件系统统计信息
53os.symlink(src, dst)----创建一个软链接
54os.tcgetpgrp(fd)----返回与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组
55os.tcsetpgrp(fd, pg)—设置与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组为pg
56os.tempnam([dir[, prefix]])----Python3 中已删除。返回唯一的路径名用于创建临时文件
57os.tmpfile()----python3 中已删除。返回一个打开的模式为(w+b)的文件对象 .这文件对象没有文件夹入口,没有文件描述符,将会自动删除
58os.tmpnam()----Python3 中已删除。为创建一个临时文件返回一个唯一的路径
59os.ttyname(fd)----返回一个字符串,它表示与文件描述符fd 关联的终端设备。如果fd 没有与终端设备关联,则引发一个异常
60os.unlink(path)----删除文件路径
61os.utime(path, times)----返回指定的path文件的访问和修改的时间
62os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]])----输出在文件夹中的文件名通过在树中游走,向上或者向下。
63os.write(fd, str)----写入字符串到文件描述符 fd中. 返回实际写入的字符串长度
64os.path 模块----获取文件的属性信息。

4、Datetime模块

调用Datetime模块,能够高效的处理时间数据。
具体操作方法:https://blog.csdn.net/cmzsteven/article/details/64906245

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值