zoukankan      html  css  js  c++  java
  • day 11总结(文件的高级应用/函数)

    一、文件的高级应用

    1.可读、可写

    • r+t:可读、可写
    • w+t:可写、可读
    • a+t:可追加、可读
    # wt
    with open('test.txt', 'wt', encoding='utf8') as fw:
        print(fw.readable())
        print(fw.writable())
    
    False
    True
    
    # w+t
    with open('test.txt', 'w+t', encoding='utf8') as fw:
        print(fw.readable())
        print(fw.writable())
    
    True
    True
    
    # r+t
    with open('test.txt', 'r+t', encoding='utf8') as fr:
        print(fr.readable())
        print(fr.writable())
    
    True
    True
    

    2.文件内指针移动

    注意:硬盘上从来没有修改一说,硬盘上只有覆盖,即新内容覆盖新内容。

    2.1 seek(offset,whence)

    • offset代表文件指针的偏移量,单位是字节。
    # seek()
    with open('test.txt', 'rt', encoding='utf8') as fr:
        print(fr.seek(3, 0))  # 0相当于文件头开始;1相当于当前文件所在位置;2相当于文件末尾
        # fr.seek(0,2)  # 切换到文件末尾
    

    3

    2.2 tell():

    • 每次统计都是从文件开头到当前指针所在位置。
    # tell()
    with open('test.txt', 'rt', encoding='utf8') as fr:
        fr.seek(4, 0)
        print(fr.tell())
    

    4

    2.3 read(n)

    • 只有在模式下的read(n),n代表的是字符个数,除此之外,其他但凡涉及文件指针的都是字节个数。
    # read()
    with open('test.txt', 'rt', encoding='utf8') as fr:
        print(fr.read(3))
    
    asd
    

    2.4 truncate(n)

    • truncate(n)是截断文件,所以文件的打开方式必须可写,但是不能用w或w+等方式打开,因为那样直接清空文件了,所以truncate()要在r+或a或a+等模式下测试效果。它的参照物永远是文件头。并且truncate()不加参数,相当于清空文件。
    # truncate()
    with open('test.txt', 'r+t', encoding='utf8') as fr:
        fr.truncate(3)
    

    二、文件修改的两种方式

    ​ 文件的数据是存放于硬盘上的,因而只存在覆盖、不存在修改这么一说,我们平时看到的修改文件,都是模拟出来的效果,具体的说有两种实现方式。

    1.方式一

    ​ 将硬盘存放的该文件的内容全部加载到内存,在内存中是可以修改的,修改完毕后,再由内存覆盖到硬盘(word,vim,nodpad++等编辑器)。

    import os
    
    with open('test.txt') as fr, 
            open('test_swap.txt', 'w') as fw:
        data = fr.read()  # 全部读入内存,如果文件很大,会很卡
        data = data.replace('TBB', 'tbb')  # 在内存中完成修改
    
        fw.write(data)  # 新文件一次性写入原文件内容
    
    # 删除原文件
    os.remove('test.txt')
    # 重命名新文件名为原文件名
    os.rename('test_swap.txt', 'test.txt')
    print('done...')
    

    done...

    2.方式二

    ​ 将硬盘存放的该文件的内容一行一行地读入内存,修改完毕就写入新文件,最后用新文件覆盖源文件。

    import os
    
    with open('test.txt') as fr,
            open('test_swap.txt', 'w') as fw:
        # 循环读取文件内容,逐行修改
        for line in fr:
            line = line.replace('TBB', 'tbb')
            # 新文件写入原文件修改后内容
            fw.write(line)
    
    os.remove('test.txt')
    os.rename('test_swap.txt', 'test.txt')
    print('done...')
    

    done...

    ​ 总而言之,修改文件内容的思路为:以读的方式打开原文件,以写的方式打开一个新的文件,把原文件的内容进行修改,然后写入新文件,之后利用os模块的方法,把原文件删除,重命名新文件为原文件名,达到以假乱真的目的。

    三、函数的定义

    1.什么是函数?

    ​ 在程序中,函数就是具备某一功能的工具,事先将工具准备好就是函数的定义,遇到应用场景拿来就用就是函数的调用。

    2.为何使用函数?

    如果不使用函数,写程序时将会遇到这三个问题:

    1. 程序冗长
    2. 程序的扩展性差
    3. 程序的可读性差

    3.如何使用函数

    3.1定义函数

    • 函数的定义阶段: 只检测语法,不执行函数体代码。
    def 函数名(num1、num2……):  #这里的num为形参
        """
        函数功能的描述信息
        :param1:描述
        :param2:描述
        :return:返回值
        """
        code 1
        code 2
        code 3
        ...
    
        return 返回值
    

    3.2调用函数

    • 执行函数体内的代码
    函数名(num1、num2……)   #这里的num为实参
    

    四、定义函数的三种方式

    1.无参函数

    ​ 定义函数时参数是函数体接收外部传值的一种媒介,其实就是一个变量名

    ​ 在函数阶段括号内没有参数,称为无参函数。需要注意的是:定义时无参,意味着调用时也无需传入参数。

    ​ 如果函数体代码逻辑不需要依赖外部传入的值,必须得定义成无参函数。

    def func():
        print('hello world')
    

    2.有参函数

    ​ 在函数定义阶段括号内有参数,称为有参函数。需要注意的是:定义时有参,意味着调用时也必须传入参数。

    ​ 如果函数体代码逻辑需要依赖外部传入的值,必须得定义成有参函数。

    def sum_self(x, y):
        """求和"""
        res = x+y
        print(res)
    
    sum_self(1,2)  # 3
    

    3.空函数

    ​ 当只知道你需要实现某个功能,但不知道该如何用代码实现时,你可以暂时写个空函数,然后先实现其他的功能。

    def func():
        pass
    

    五、函数的返回值

    1.什么是返回值?

    函数内部代码经过一些列逻辑处理获得的结果。

    2.为什么要有返回值?

    如果需要在程序中拿到函数的处理结果做进一步的处理,则需要函数必须要有返回值。

    需要注意的是:

    • return是一个函数结束的标志,函数内可以有多个return,只要执行到return,函数就会执行。
    • return的返回值可以返回任意数据类型
    • return的返回值无个数限制,即可以使用逗号隔开返回多个值
      • 0个:返回None
      • 1个:返回值是该值本身
      • 多个:返回值是元组

    六、函数的调用

    1.什么是函数调用?

    函数名(…)即调用函数,会执行函数体代码,直到碰到return或者执行完函数体内所有代码结束。

    2.函数调用的三种形式

    def max_self(x,y):
        if x>y:
            return x
        else:
            return y
        
    # 1.
    max_self(1,2)
    # 2.
    res = max_self(1,2)*12
    # 3.
    max_self(max_self(20000,30000),40000)
    

    七、函数的参数

    1.形参和实参

    1.1 形参

    ​ 在函数定义阶段括号内定义的参数,称之为形式参数,简称形参,本质就是变量名。

    def func(x, y):
        print(x)
        print(y)
    

    1.2 实参

    ​ 在函数调用阶段括号内传入的参数,称之为实际参数,简称实参,本质就是变量的值。

    func(1, 2)

    2.位置参数

    2.1 位置形参

    ​ 在函数定义阶段,按照从左到右的顺序依次定义的形参,称之为位置形参。

    def func(x, y):
        print(x)
        print(y)
    

    特点:按照位置定义的形参,都必须被传值,多一个不行,少一个也不行。

    2.2 位置实参

    ​ 在函数调用阶段,按照从左到右的顺序依次定义的实参,称之为位置实参。

    func(1, 2)

    特点:按照位置为对应的形参依次传值。

    3.关键字实参

    ​ 在调用函数时,按照key=value的形式为指定的参数传值,称为关键字实参。

    特点:可以打破位置的限制,但仍能为指定的形参赋值。

    注意:

    1. 可以混用位置实参和关键字实参,但是位置实参必须在关键字实参的左边。
    2. 可以混用位置实参和关键字实参,但不能对一个形参重复赋值。
    func(x, y=2)
    func(y=2, x)  
    func(x, x=1)
    

    4.默认形参

    • 在定义阶段,就已经被赋值。

    • 默认参数的值通常应该是不可变类型。

    def func(x, y=10):
        print(x)
        print(y)
        
    func(2)
    

    特点:在定义阶段就已经被赋值,意味着在调用时可以不用为其赋值。

    注意:

    1. 位置形参必须放在默认形参的左边。
    2. 默认形参的值只在定义阶段赋值一次,也就是说默认参数的值在函数定义阶段就已经固定了。

    5.总结

    实参的应用:取决于个人习惯
    形参的应用:

    1. 大多数情况的调用值一样,就应该将该参数定义成位置形参
    2. 大多数情况的调用值一样,就应该将该参数定义成默认形参
  • 相关阅读:
    洛谷P1514引水入城
    洛谷P2827蚯蚓
    外部排序总结
    桶排序
    基数排序
    计数排序
    搜索文件-读目录的使用
    堆排序
    甲乙用同一串数字玩游戏
    Cracking the Coding Interview 8.7
  • 原文地址:https://www.cnblogs.com/mgytz/p/11322361.html
Copyright © 2011-2022 走看看