zoukankan      html  css  js  c++  java
  • python-day11(正式学习)

    文件高级应用

    多重操作

    r+t:可读,可写(文件名为a)

    with open('a','r+',encoding='utf-8')as f:
        data=f.read()
        print(data)
        data=data.replace('d','m')
        print(data)
        f.truncate(0)  #截断文件内原内容
        f.write(data)  #对文件内容的一个修改,注意如果指针在文本内容前面,添加时新内容会覆盖原内容,而不是插入新内容
    
                                                               asdasdasd
                                                               asmasmasm
    

    w+t:可写可读

    with open('a','w+',encoding='utf-8')as f:  #但凡w/w+操作都会在此时先清空原内容
        f.write('ww')
        data=f.read()
        print(data)  #写入时指针在最后,所以读不到任何内容
    

    a+t:可追加可读

    with open('a','a+',encoding='utf-8')as f:
        f.write('Nihao')
        data=f.read()
        print(data)  #该模式下指针始终在文件末端,想要读内容必须先移动指针
    

    文件内指针移动及一些操作

    指针移动seek(offset,whence)

    offset代表文件指针的偏移量,单位是字节

    # seek()
    with open('36r.txt', 'rt', encoding='utf-8') as fr:
        print(f"fr.seek(4, 0): {fr.seek(3, 0)}")  # 0相当于文件头开始;1相当于当前文件所在位置;2相当于文件末尾
        # fr.seek(0,2)  # 切换到文件末尾
    
    fr.seek(4, 0): 3
    

    寻找指针位置tell()

    # tell()
    with open('36r.txt', 'rt', encoding='utf-8') as fr:
        fr.seek(4, 0)
        print(f"fr.tell(): {fr.tell()}")
    
    fr.tell(): 4
    

    读取部分字符read(n)

    只有在模式下的read(n),n代表的是字符个数,除此之外,其他但凡涉及文件指针的都是字节个数

    # read()
    with open('36r.txt', 'rt', encoding='utf-8') as fr:
        print(f"fr.read(3): {fr.read(3)}")
    
    fr.read(3): sdf
    

    截断文件内容truncate(n)

    truncate(n)是截断文件,所以文件的打开方式必须可写,但是不能用w或w+等方式打开,因为那样直接清空文件了,所以truncate()要在r+或a或a+等模式下测试效果。它的参照物永远是文件头。并且truncate()不加参数,相当于清空文件。

    # truncate()
    with open('36r.txt', 'r+t', encoding='utf-8') as fr:
        fr.truncate(3)
    

    文件的修改

    方式一

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

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

    方式二

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

    import os
    
    with open('37r.txt') as fr,
            open('37r_swap.txt', 'w') as fw:
        # 循环读取文件内容,逐行修改
        for line in fr:
            line = line.replace('jason', 'jasonSB')
            # 新文件写入原文件修改后内容
            fw.write(line)
    
    os.remove('37r.txt')
    os.rename('37r_swap.txt', '37r.txt')
    

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

    函数

    什么是函数

    假设现在你是下水道工,如果你事先准备好你的工具箱,等你接到修理下水道的工作的时候,你直接把你的工具箱拿过去直接使用就行了,而不需要临时准备锤子啥的。

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

    为什么要用函数

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

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

    如何用函数

    先定义函数后调用

    定义函数

    def 函数名(param1、param2……):
        """
        函数功能的描述信息
        :param1:描述
        :param2:描述
        :return:返回值
        """
        code 1
        code 2
        code 3
        ...
    
        return 返回值
    

    调用函数

    函数名(param1、param2……)
    

    定义函数的三种形式

    无参函数

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

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

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

    def func():
        print('hello nick')
        
    func()  # hello nick
    

    有参函数

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

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

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

    空函数

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

    def func():
        pass
    

    函数的返回值

    什么是返回值

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

    def func():
        name = 'nick'
        return name
    
    
    name = func()
    print(name)
    
    nick
    

    为什么要有返回值

    现在有一个需求,比较两个人的月薪,然后想获取月薪较大人的年薪。

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

    需要注意的是:

    • return是一个函数结束的标志,函数内可以有多个return,只要执行到return,函数就会执行。
    • return的返回值可以返回任意数据类型
    • return的返回值无个数限制,即可以使用逗号隔开返回多个值
      • 0个:返回None
      • 1个:返回值是该值本身
      • 多个:返回值是元组
    # 为什么要有返回值
    def max_self(salary_x, salary_y):
        if salary_x > salary_y:
            return salary_x
        else:
            return salary_y
    
    
    max_salary = max_self(20000, 30000)
    print(max_salary*12)
    
    360000
    

    函数的调用

    什么是函数调用

    第一次将函数其实就讲了函数的调用,但是你不得不再次更新你对函数调用的印象。函数名(…)即调用函数,会执行函数体代码,直到碰到return或者执行完函数体内所有代码结束。

    函数运行完毕所有代码,如果函数体不写return,则会返回None。

    def foo():
        pass
    
    print(foo())
    
    None
    

    为什么调用函数

    使用函数的功能

    函数调用的三种形式

    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)
    

    形参和实参

    形参

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

    实参

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

    位置形参

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

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

    位置实参

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

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

    关键字实参

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

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

    注意:

    1. 可以混用位置实参和关键字实参,但是位置实参必须在关键字实参的左边。
    2. 可以混用位置实参和关键字实参,但不能对一个形参重复赋值。
    func(x, y=2)
    func(y=2, x)  # SyntaxError: positional argument follows keyword argument
    func(x, x=1)  # NameError: name 'x' is not defined
    

    默认形参

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

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

    注意:

    1. 位置形参必须放在默认形参的左边。
    2. 默认形参的值只在定义阶段赋值一次,也就是说默认参数的值在函数定义阶段就已经固定了。
    m = 10
    
    
    def foo(x=m):
        print(x)
    
    
    m = 111
    foo()  # 10
    
  • 相关阅读:
    Codeforces 1485C Floor and Mod (枚举)
    CodeForces 1195D Submarine in the Rybinsk Sea (算贡献)
    CodeForces 1195C Basketball Exercise (线性DP)
    2021年初寒假训练第24场 B. 庆功会(搜索)
    任务分配(dp)
    开发工具的异常现象
    Telink MESH SDK 如何使用PWM
    Telink BLE MESH PWM波的小结
    [LeetCode] 1586. Binary Search Tree Iterator II
    [LeetCode] 1288. Remove Covered Intervals
  • 原文地址:https://www.cnblogs.com/leaf-wind/p/11321505.html
Copyright © 2011-2022 走看看