系列第三篇来说一下函数和文件。函数在编程中是一个很重要的角色,我们可以将若干个语句组合形成一个函数,它可以接受传入参数,并在内部进行相关计算后产生输出,将语句封装成函数是为了避免重复使用几个语句造成代码冗杂,让代码更简洁可观性更强。文件的操作主要是介绍一些关于文件的读取及写入的方法,以及每个方法的不同点和需要注意的事项,最后会介绍一下利用pickle模块存储复杂数据的方式。

函数

函数主要包括两个方面:

  • 内置函数

  • 自定义函数

内置函数就是python自带的一些函数,我们只需要给函数传入相关参数就可以进行调用,print就是最基础、最典型的一个内置函数;而自定义函数是需要我们自己按照需求,封装若干个语句形成一个新的函数。

自定义函数

1.创建函数

下面通过自定义一个计算长方体体积的函数来介绍一些属性词:

In [1]: def  vol(length,width,height):   ...:     volume = length*width*height   ...:     return volume

上面三行代码中你需要了解:

  • def:定义函数的关键字

  • length,width,height:函数的形参

  • return:函数的返回值

2.调用函数

建好一个自定义函数后,可以通过函数名(实参)的方式调用函数:

In [2]: vol(2,2,3)Out[2]: 12

在传入参数时需要注意的是,实参与形参必须完全对应,比如位置、个数等等,否则会出现报错。

In [4]: vol(2,2)TypeError: vol() missing 1 required positional argument: 'height'

如果想改变传参顺序,那么你需要指定为哪一个形参传值:

In [8]: vol(width=3,length=4,height=5)Out[8]: 60

3.函数默认值

函数的形参还可以指定默认值,假如我们将上面的vol函数中height参数默认值设为2:

In [6]: def  vol(length,width,height=2):   ...:     volume = length*width*height   ...:     return volume   ...:In [7]: vol(2,2)Out[7]: 8

这时只向vol函数中传入两个实参,可以发现没有报错,并且得到返回值为8。也就是说如果一个形参有默认值,而调用函数时没有为这个形参传值,那么这个参数就取默认值。

4.收集函数(可变函数)

对于一个函数的形参我们也可以将其设置为可以变化的:

In [9]: def test(*params):   ...:     print('参数的长度为%d'%len(params))   ...:     print('第三个参数为%s'%params[2])   ...:In [10]: test(1,2,'mao',3.14,'pp')参数的长度为5第三个参数为mao

这里需要将形参用*标识,然后在调用参数的时候可以传入若干个实参。

5.全局与局部

在函数中定义的常量被称为局部变量,也就是仅限在这个函数中可以调用,不接受在函数之外使用:

In [12]: def test(a,b):    ...:     c = 2    ...:     return a*b*cIn [13]: test(2,2)Out[13]: 8In [14]: print(c)NameError: name 'c' is not defined

6.匿名函数lambda

如果一个函数内部的语句不是很复杂,代码量很少,我们就可以利用匿名函数,比如上面计算体积的函数:

In [20]: vol = lambda a,b,c:a*b*cIn [21]: vol(2,2,3)Out[21]: 12

lambda表达式常常嵌套的语句中,结合相关函数使用会很简便,后面会给出例子。

7.内嵌函数

在定义函数时还支持几个函数嵌套,但用的时候需要注意逻辑关系:

In [24]: def fun1(a):    ...:     b = 2    ...:     def fun2():    ...:         return a*b    ...:     return fun2()    ...:In [25]: fun1(4)Out[25]: 8

常用内置函数

内置函数前两篇文章就有涉及过,比如常用的len、sorted、reversed、sum等等,除此之外再介绍几个比较基础的内置函数。

1.max和min

求一个序列中最大值和最小值:

In [28]: min(1,2,3)Out[28]: 1In [29]: max(1,2,3)Out[29]: 3

2.abs

求一个数的绝对值:

In [31]: abs(-1)Out[31]: 1

3.round

四舍五入保留小数点后几位:

In [32]: round(3.555,2)Out[32]: 3.56

4.pow

计算一个数的幂次方,或者再取余:

In [33]: pow(2,3)#2*2*2Out[33]: 8In [34]: pow(2,3,3)#(2*2*2)%3Out[34]: 2

5.divmod

计算一个数的商和余数:

In [36]: divmod(10,3)Out[36]: (3, 1)

6.help

用来查询一个函数的帮助文档:

In [37]: help(abs)Help on built-in function abs in module builtins:abs(x, /)    Return the absolute value of the argument.

7.filter

filter()函数接收两个参数,第一个参数可以是一个函数或者None,第二个参数是序列。作用是对每个元素进行判断,返回 True或 False,filter()根据判断结果自动过滤掉序列中为False的元素,留下为True的元素,可以结合lambda表达式使用:

In [38]: list(filter(lambda x:x%2,range(10)))Out[38]: [1, 3, 5, 7, 9]

8.map

map()函数接收两个参数,一个是函数,一个是序列。作用是将函数应用于序列中每一个元素上,同样可以结合lambda表达式使用:

In [42]: list(map(lambda x: x*2,range(10)))Out[42]: [0, 2, 4, 6, 8, 10, 12, 14, 16, 18]

文件

关于文件读写操作,open()函数是一定遇到的,如果文件已经存在则会打开文件,若不存在则会创建一个文件,通常的用法需要两个参数:open(filename,mode)。

第一个参数就是文件名字,第二个参数就指定文件将会被如何使用,可选模式常用的有以下几种:

  • 'r':以只读的方式打开文件(默认)

  • 'w':以写入模式打开文件,会覆盖已存在的文件

  • 'a':以写入模式打开文件,如果文件存在,则在末尾追加写入

  • 'b':以二进制模式打开文件,进而会有rb、wb等模式组合

1.read()方法读取

read()方法可传入一个参数size,也就是读取内容的长度。size是一个可选参数,如果不传入或者传入一个负数,那么会读取文件全部内容:

In [52]: fb = open('E:/Python基础/test.txt','r')In [53]: fb.read(10)Out[53]: 'nai\nniatan'In [54]: fb.read()Out[54]: 'g\nnaitangmao'In [55]: fb.read()Out[55]: ''

需要注意的有三点:

  • 1、原文件中换行的地方在读取时以换行符'\n'表示,并且也占有一个单位长度

  • 2、已经被读取的内容不能被重复读取

  • 3、如果读取内容返回为空字符串,表示已经到了文件末尾

2.readline()方法

readline()方法是从文件中读取单独一行,并且在这一行数据的末尾处会有一个换行符'\n',如果其中一行没有数据,则会只返回一个'\n',同样当返回空字符串时表示到达文件末尾。

In [59]: fb1 = open('E:/Python基础/test.txt','r')In [60]: fb1.readline()Out[60]: 'nai\n'

3.readlines()方法

readlines()方法也是用来读取全部文件,与read()不同之处在于前者是按行读取,并且最后返回的是一个列表,每一行数据作为一个列表元素:

In [72]: fb3 = open('E:/Python基础/test.txt','r')In [73]: fb3.readlines()Out[73]: ['nai\n', 'niatang\n', 'naitangmao']

4.遍历文件对象读取

这种方式读取出的内容看起来会比较规范一些:

In [81]: for i in fb4:    ...:     print(i,end = '')    ...:nainiatangnaitangmao

5.文件的写入

在进行写入操作的时候,我们需要注意的两个点:

  • 写入的数据如果是非字符串内容,需要转换为字符串

  • 写入的方式要注意是覆盖还是追加

In [85]: fb5 = open('E:/Python基础/test1.txt','w')In [89]: list1 = [1,2]In [91]: fb5.write(str(list1))Out[91]: 6

用write写入后会返回写入字符串的长度。

6.文件关闭

切记切记切记!如果你用open()的方式打开一个文件,在操作完成之后一定要用close()方法关闭文件。

In [92]: fb5.close()

7.with方式

如果你感觉自己的记性不好,总是忘记用close()方法关闭文件,那么就要习惯利用with处理文件对象,它可以在文件用完之后自动关闭文件。

In [93]: with open('E:/Python基础/test.txt','r') as fb:    ...:     data = fb.read()In [95]: fb.closedOut[95]: True

8.pickle

上面说了将一个非字符串写入文件是不允许的,如果有没有办法保存一份字典或者列表形式的数据呢?pickle模块就可以实现这种序列化的存储与读取:

In [96]: import pickleIn [97]: list1 = ['nai','tang','mao',1,2,3]In [98]: pic_f = open('E:/Python基础/list.pkl','wb')In [99]: pickle.dump(list1,pic_f)In [100]: pic_f.close()

dump()方法接收两个参数,第一个是要存储的内容,第二个是存储的文件对象,操作之后也需要用close()关闭文件对象,存储之后可以利用load()方法加载文件中的内容。

In [102]: pic_f = open('E:/Python基础/list.pkl','rb')In [103]: list2 = pickle.load(pic_f)In [104]: list2Out[104]: ['nai', 'tang', 'mao', 1, 2, 3]In [105]: pic_f.close()

利用pickle在存储或者读取的时候要注意以二进制的形式操作文件对象,也就是'wb'和'rb',pickle很适合用来存储数据类型比较复杂并且数据量又很大的数据。

往期推介:

  1. 牛逼!Python常用数据类型的基本操作(长文系列第一篇)

  2. 牛逼!Python的判断、循环和各种表达式(长文系列第2篇)

open函数返回-1_牛逼!Python函数和文件操作(长文系列第3篇)相关推荐

  1. open函数返回-1_记录学习python的第3天-递归函数/文件操作

    中午吃过饭,就开始码起来啦! 希望没有大佬看到,学的还挺基础的.算法也是很简单的题目.不过写这些文章也仅仅是,悦人者众 ,悦己者王嘛! 算法题: python算法题 <python算法题> ...

  2. python中查看表头的函数_Python中也可以写Excel中的“Vlookup”函数?太牛逼了吧!...

    原标题:Python中也可以写Excel中的"Vlookup"函数?太牛逼了吧! Vlookup函数,可以算是一个数据专员必须要会使用的基本函数了,确实很好用.但是你可能会注意到, ...

  3. 牛逼!Python错误、异常和模块(长文系列第4篇)

    系列第四篇主要讲两方面,错误和异常以及模块.在编程时遇见错误信息在所难免,Python中会也有很多种错误信息,常见的两种就是语法错误和逻辑错误,逻辑错误的种类有很多,占据了异常中大部分位置,下面就开始 ...

  4. linux 变量函数返回值,linux shell 自定义函数(定义、返回值、变量作用域)介绍...

    linux shell 可以用户定义函数,然后在shell脚本中可以随便调用.下面说说它的定义方法,以及调用需要注意那些事项. 一.定义shell函数(define function) 语法: [ f ...

  5. C语言练习题,三色球抽取,从3个红球,5个白球,6个黑球中任意取出8个作为一组进行输出。在每组中可以没有黑球,但必须要有红球和白球。编程实现以上功能。用函数返回其组合数,在函数中打印每组的组合

    三色球分组 从3个红球,5个白球,6个黑球中任意取出8个作为一组进行输出.在每组中可以没有黑球,但必须要有红球和白球.编程实现以上功能.用函数返回其组合数,在函数中打印每组的组合 函数原型为: int ...

  6. (14年)2.写一个函数int func(int n)其返回值是n的逆序整数,例如n=123函数返回321.n=72839,函数返回93827

    #include <stdio.h> #include <stdlib.h> /*写一个函数int func(int n)其返回值是n的逆序整数 例如n=123.函数返回321 ...

  7. python怎么读取文件-python怎么读写文件操作

    本节内容:I/O操作概述 文件读写实现原理与操作步骤 文件打开模式 Python文件操作步骤示例 Python文件读取相关方法 文件读写与字符编码 一.I/O操作概述 I/O在计算机中是指Input/ ...

  8. Python中的文件操作和异常

    Python中的文件操作和异常 文章目录 Python中的文件操作和异常 一.文件 01. 文件的概念 1.1 文件的概念和作用 1.2 文件的存储方式 文本文件和二进制文件 02. 文件的基本操作 ...

  9. Python os模块文件操作(二)

    Python os模块文件操作(二) os模块对文件夹和文件的操作很多.可以先看: https://blog.csdn.net/weixin_43790276/article/details/9867 ...

  10. python怎么读写文件-python怎么读写文件操作

    本节内容:I/O操作概述 文件读写实现原理与操作步骤 文件打开模式 Python文件操作步骤示例 Python文件读取相关方法 文件读写与字符编码 一.I/O操作概述 I/O在计算机中是指Input/ ...

最新文章

  1. windows启动mysql8服务_MySQL8.0服务启动(windows10)
  2. 利用UDEV服务解决RAC ASM存储设备名
  3. java获取u盘_实例分享java监听u盘的方法
  4. Linux之yum安装lamp环境
  5. (vue基础试炼_03)使用vue.js实现TodoList
  6. sliverlight3 学习 2, 布局
  7. asteroids模板 游戏 java_在高级Java游戏中存储全局/静态变量的最佳方法是什么?...
  8. 鸿蒙开源代码数量,消息称华为鸿蒙此次开源代码量大约是 8GB,AOSP 超 60GB
  9. 用Blink打造你的技术朋友圈
  10. 6 个步骤,搞定 AI 车牌识别器!(附详细分析)
  11. 警告:Establishing SSL connection without server’s identity verification is not recommended
  12. mschart控件_使用MSChart控件绘制图表。
  13. 【数学建模】——1992~2019国赛优秀论文
  14. PTCRB/GCF 认证测试问题总结
  15. 分析攻击IP来源地并画出饼图 1
  16. 华东师范计算机科学与技术 导师,钱莹 - 华东师范大学 - 计算机科学与技术学院...
  17. 未来几年学什么设计更有前途?
  18. file html5 样式,CSS小技巧之自定义个性的file表单样式
  19. python:实现红黑树算法(附完整源码)
  20. FPGA概念理解之:ZYNQ、PS、PL、APU、ARM、SOC、URAT、GPIO...

热门文章

  1. Java 8 vs. Scala(二):Stream vs. Collection
  2. String.getBytes()方法中的中文编码问题(转)
  3. 2013年吴超的个人总结
  4. 大学生必看的一分钟——俞洪敏语录
  5. 在IE浏览器中url传参长度问题
  6. exception内置对象
  7. Python内置函数(17)——chr
  8. HTML(超文本语言)
  9. DragSortListView可拖拽ListView的注意事项
  10. [leetcode] @python 113. Path Sum II