首页 > 编程语言 >Python基础学习day11

Python基础学习day11

时间:2023-09-13 10:05:02浏览次数:52  
标签:utf 函数 Python 学习 msg read day11 print txt

1、文件

1.1.控制文件内指针的移动

文件内指针移动,只有t模式下的read(n),n代表的字符的个数
除此以外文件内指针的移动都是以字节为单位

with open('a.txt',mode='rt',encoding='utf-8') as f:
    msg=f.read(1)#t模式下的read,按照字符数来移动
    print(msg)

with open('a.txt',mode='rb') as f:
    msg=f.read(3)#t模式以外的的所有指针移动,按照字节数来移动
    print(msg.decode('utf-8'))

1.1.1 f.seek(offset,whence)有两个参数:

  offset: 代表控制指针移动的字节数
  whence: 代表参照什么位置进行移动
  whence = 0: 参照文件开头(默认的),特殊???,可以在t和b模式下使用
  whence = 1: 参照当前所在的位置,必须在b模式下用
  whence = 2: 参照文件末尾,必须在b模式下用

with open('a.txt',mode='rt',encoding='utf-8') as f:
    f.seek(6,0)#指针从文件开头起的第6个字节开始
    msg=f.read(1)#读取一个字符
    print(msg)
with open('a.txt',mode='rb') as f:
    f.seek(3,0)#指针从文件开头算起的第3个字节开始
    msg=f.read(3)#读取3个字节
    print(msg.decode('utf-8'))
with open('a.txt',mode='rb') as f:
    msg=f.read(3)#读取三个字节
    print(msg.decode('utf-8'))
    f.seek(3,1)#指针从当前位置算起,移动3个字节
    msg1=f.read(3)#读取三个字节
    print(msg1.decode('utf-8'))
with open('a.txt',mode='rb') as f:
    f.seek(0,2)#指针移动到文件末尾
    print(f.tell())#打印为空,因为文件末尾后面没有任何内容
    f.seek(-3,2)#指针移动到以文件末尾算起,往前3个字节
    msg=f.read(3)
    print(msg.decode('utf-8'))

1.2.文件修改的两种方式

1.2.1 修改文件的方式一:

1 将文件内容由硬盘全部读入内存
2 在内存中完成修改
3 将内存中修改后的结果覆盖写回硬盘

with open('d.txt',mode='rt',encoding='utf-8') as f:
    all_data=f.read()
    print(all_data,type(all_data))

with open('d.txt',mode='wt',encoding='utf-8') as f:
    f.write(all_data.replace('alex','dsb'))
1.2.1.1 错误的做法
with open('d.txt',mode='rt',encoding='utf-8') as f1,open('d.txt',mode='wt',encoding='utf-8') as f2:
    all_data=f1.read()
    f2.write(all_data.replace('dsb','alex'))

 

1.2.2 修改文件的方式二:

1 以读的方式打开源文件,以写的方式打开一个临时文件
2 从源文件中每读一样内容修改完毕后写入临时文件,直到源文件读取完毕
3 删掉源文件,将临时文件重命名为源文件名

import os

with open('d.txt',mode='rt',encoding='utf-8') as read_f,open('.d.txt.swap',mode='wt',encoding='utf-8') as write_f:
    for line in read_f:
        write_f.write(line.replace('alex','dsb'))

os.remove('d.txt')
os.rename('.d.txt.swap','d.txt')

1.2.3 总结

方式一:
优点: 在文件修改的过程中硬盘上始终一份数据
缺点: 占用内存过多,不适用于大文件

方式二:
优点: 同一时刻在内存中只存在源文件的一行内容,不会过多地占用内存
缺点: 在文件修改的过程中会出现源文件与临时文件共存,硬盘上同一时刻会有两份数据,即在修改的过程中会过多的占用硬盘,

2、函数的基本使用

2.1 什么是函数

函数就是具备某一功能的工具

2.2 为什么要用函数

1 程序的组织结构不清晰,可读性差
2 代码冗余
3 可扩展性差

2.3 如何用函数

函数的使用必须遵循的原则:先定义,后调用
修理工事先准备工具的过程即函数的定义
修理工遇到应用场景拿来工具就用即函数的调用

语法:

def 函数名(参数1,参数2,...):
    """
    文档注释
    """
    code1
    code2
    code3
    ......
    return 返回值

def:定义函数的关键字
函数名: 就相当于一个变量名,指向函数的内存地址,
  注意:函数的内存地址()就可以出发函数体代码的执行

参数: 参数是函数的调用者为函数体代码传值的媒介,在python中函数的参数无需声明类型
"""文档注释""" : 推荐写上
代码块:就是函数体功能的具体实现
return 返回值 :函数体代码块运行的成果

函数的使用分为两个阶段:
定义阶段: 只检测语法,不执行代码
调用阶段:运行函数体代码

#先定义
def foo():
    print("from foo")

#后调用
print(foo)
foo() 定义时无参,意味着调用时也无需传入参数

#先定义
def bar(x,y):
    print(x)
    print(y)
#后调用
bar('a',2) 定义时无参,意味着调用时也必须传入参数

定义无参函数:当函数体的代码逻辑不依赖任何传入的值就能执行,就不需要定义参数

def print_msg():
    print('='*50)
    print('welecome.....'.center(50,' '))
    print('='*50)

    print_msg()
    print_msg()

定义有参函数:当函数体的代码逻辑依赖于外部调用者传入的值才能执行,必须定义参数用来接收外部传入的值

def max2(x,y):
    x=1
    y=3
    if x > y:
        print(x)
    else:
        print(y)
max2(1,4)#3,内部有下,x y,所以不需要传入参数


def max2(x,y):
    if x > y:
        return x
    else:
        return y
res=max2(1,4)
print(res)#4

标签:utf,函数,Python,学习,msg,read,day11,print,txt
From: https://blog.51cto.com/u_15130867/7451835

相关文章

  • 基于Python实现一个在线加密解密网站系统
    在这个数字化时代,数据的安全和隐私变得越来越重要。想象一下,如果我们之间的通信被窃听,或者我们存储的数据被不正当地访问,将会有怎样的后果?这就是为什么加密技术在现代技术领域中变得如此重要的原因。但加密技术听起来可能有些高深,让很多人望而生畏。今天,我要带领大家实现一个简单......
  • PYTHON 1
    importsysfromtimeimportsleepimportkeyboardfromPILimportImage,ImageGrab'''frombaiDuimportbaiDuAPIfromgetTextimportGetText'''defscreenshot():'''用于截图保存'''ifkeyboard......
  • 使用Python调用Hadoop Hdfs的API
    一、Java调用hdfs的apiimportorg.apache.hadoop.conf.Configuration;importorg.apache.hadoop.fs.FileSystem;importorg.apache.hadoop.fs.Path;importorg.junit.After;importorg.junit.Before;importorg.junit.Test;importjava.io.IOException;importjava.net......
  • Python用正则化Lasso、岭回归预测房价、随机森林交叉验证鸢尾花数据可视化2案例
    全文链接:https://tecdat.cn/?p=33632原文出处:拓端数据部落公众号机器学习模型的表现不佳通常是由于过度拟合或欠拟合引起的,我们将重点关注客户经常遇到的过拟合情况。过度拟合是指学习的假设在训练数据上拟合得非常好,以至于对未见数据的模型性能造成负面影响。该模型对于训练数......
  • 前端学习Day01
    Html第一节:初识heml定义:html是一种用于创建网页的标记语言,通过标签来描述页面的不同部分和元素。页面元素:构成网页结构和内容的基本单元,比如:标题,段落,图像,连接,表格等等。第一个标签:<marquee>跑马灯的效果<marquee>你好,前端!</marquee>什么是标签:标签可以写大写也可以写小写,但是标准......
  • Python使用 - NumPy用法1
    NumPy的核心数据结构之一是ndarray,表示一个多维数组,他存储的是单一数据类型。 导入包importnumpyasnp 1维数组list1=[1,2,3,4,5,6]ndarr1=np.array(list1,dtype=np.float32)print(type(ndarr1),ndarr1)#<class'numpy.ndarray'>[1.2.3.4.5.6.]......
  • Go学习笔记5
    十六、基于TCP协议的网络通信创建客户端【1】调用Dial函数:(net包下)【2】代码:packagemainimport("fmt""net"//所需的网络编程全部都在net包下)funcmain(){//打印:fmt.Println("客服端启动。。")//调用Dial函数:参数需要指定t......
  • Working With Strings In Python.
    #字符串操作在Python中,`string`是一种不可变的数据类型,用于表示文本或字符序列,可以使用单引号或双引号将字符串括起来。<fontcolor="#C7EDCC">所有修改和生成字符串的操作的实现方法都是另一个内存片段中新生成一个字符串对象。</font>##创建字符串```pystr1="Lefti......
  • 信息系统项目管理师教程(第四版) 第一章 信息化发展 学习笔记1-20230911
    第一章《信息化发展》 学习要点:1、信息的基本概念、信息的7个质量属性。2、信息系统的概念、特点或用途、抽象模型、信息系统生命周期。3、信息化、信息化系统。4、工业互联网(四大层级)、车联网(体系框架、链接方式、应用场景)。5、农业农村现代化、乡村振兴战略、两化融合与......
  • Java学习_005 if语句:奇偶数的判定
    需求:任意给出一个整数,使用程序判定该整数是奇数还是偶数,并在控制台输出。1importjava.util.Scanner;23publicclassMain{4publicstaticvoidmain(String[]args){5Scannersc=newScanner(System.in);6System.out.println("please......