python自动化办公(一)

本文代码参考其他教程书籍实现。

文章目录

  • 文件读写
    • open函数
    • 读取文本文件
    • 写入文本文件
  • 文件和目录操作
    • 使用os库
    • 使用shutil库

文件读写

open函数

open函数有8个参数,常用前4个,除了file参数外,其他参数都有默认值。file指定了要打开的文件名称,应包含文件路径,不写路径则表示文件和当前py脚本在同一个文件夹。buffering用于指定打开文件所用的缓冲方式,默认值-1表示使用系统默认的缓冲机制。文件读写要与硬盘交互,设置缓冲区的目的是减少CPU操作磁盘的次数,延长硬盘使用寿命。encoding用于指定文件的编码方式,如GBK、UTF-8等,默认采用UTF-8,有时候打开一个文件全是乱码,这是因为编码参数和创建文件时采用的编码方式不一样。

mode指定了文件的打开模式。打开文件的基本模式包括r、w、a,对应读、写、追加写入。附加模式包括b、t、+,表示二进制模式、文本模式、读写模式,附加模式需要和基本模式组合才能使用,如 “rb”表示以二进制只读模式打开文件,“rb+”表示以二进制读写模式打开文件。

要注意的是,凡是带w的模式,操作时都要非常谨慎,它首先会清空原文件,但不会有提示。凡是带r的文件必须先存在,否则会因找不到文件而报错。

新建文本文件python_zen.txt,将python之禅文本(import this 返回的文本)复制粘贴。保存为UTF-8无BOM编码格式
在这里插入图片描述
常见的对象方法及其作用说明

方法作用
read将文件读入字符串中,也可以读取指定字节
readline读入文件的一行到字符串中
readlines将整个文件按行读入列表中
write向文件中写入字符串
writelines向文件中写入一个行数据列表
close关闭文件
flush把缓冲区的内容写入硬盘
tell返回文件操作标记的当前位置,以文件的开头为原点
next返回下一行,并将文件操作标记位移到下一行
seek移动文件指针到指定位置
truncate截断文件

读取文本文件

# 使用open函数打开文件
f=open('./python_zen.txt',mode='r',encoding='utf-8')
type(f)#查看类型
_io.TextIOWrapper
# 使用read方法将文件读入字符串中
texts=f.read()
print(texts)#输出文件全部内容

在这里插入图片描述

f.seek(0)#移动文件指针到文件开始处
0
# 使用readline方法读入文件的一行到字符串
texts=f.readline()
print(texts)

在这里插入图片描述

# 继续使用readline方法读取
texts=f.readline()
print(texts)#第二行该行为空行

在这里插入图片描述

# 继续使用readline方法读取
texts=f.readline()
print(texts)#第三行

在这里插入图片描述

# readline方法每次只读取一行,它常常与for循环配合使用
f.seek(0)
for line in f:
    print(line,end='')

在这里插入图片描述

# readlines方法读取效果
f.seek(0)
texts=f.readlines()
print(texts)

在这里插入图片描述
readlines的效果是一次性读取整个文件,并自动将文件内容按行分解成列表。
读取完毕后要用close方法关闭文件。

f.close()

在进行Python文件的读取或者写入的时候,都需要调取close方法来关闭文件,
前者是避免占用内存,后者是保证将内容顺利写入目标文件中。
有些时候我们会忘记调用close方法,或者运行中途代码出错,导致未运行close方法。
为了避免这种情况,可以使用try…finally…结构。

try:
    f=open(r'./python_zen.txt','r')
    ...
finally:
    f.close()

这种结构简单地说:无论异常是否发生,在程序结束前,finally中的语句都会被执行。

# 此外,可以用上下文管理器with语句,确保不管使用过
# 程中是否发生异常都会执行必要的“清理”操作,以释放资源。
with open(r'./python_zen.txt','r') as f:
    texts=r.read()
    ...

统计单词出现的频率

from collections import Counter
lists=[]
punctuation=',。!?、()【】<>《》=:+-*—“”...\n'#跳过其他字符
with open('./python_zen.txt',mode='r',encoding='utf-8') as f:
    for line in f:
        for word in line.split(' '):#如果统计字母则去掉[.split(' ')]即可
            if word not in punctuation:
                lists.append(word)
counter=Counter(lists)
print(counter)

在这里插入图片描述

写入文本文件

# 写入一个文本文件
f=open(r'./python_zen_write.txt',mode='w',encoding='utf-8')
#首尾文本紧跟引号可以防止输入多余的空行
f.write(
'''The Zen of Python, by me

Beautiful is better than ugly.
Explicit is better than implicit.
Simple is better than complex.
Complex is better than complicated.
Flat is better than nested.
Sparse is better than dense.
Readability counts.'''
)
f.close()

在这里插入图片描述

# 有时,我们需要逐步写入内容,每次只写一句话,
# 这时不能用w模式,w会覆盖之前的文本内容,而应该使用追加模式a
f=open(r'./python_zen_write.txt',mode='a',encoding='utf-8')
f.write('这是python之禅的内容')
#我们尝试不运行f.close()会发生什么

打开python_zen_write.txt文件查看,想要追加写入的内容并没有写入。
在这里插入图片描述
当写文件时,操作系统往往不会立刻把数据写入硬盘,而是先放入内存中缓存起来,然后再陆续写入。只有调用close方法时,操作系统才保证把没有写入的数据全部写入硬盘。忘记调用close方法的后果是,虽然建立了文件,但是数据并没有写入文件。

# 可以使用flush方法,强制将缓存的数据写入文件
f.flush()

可以看到追加内容已经写入
在这里插入图片描述
但是似乎不是换行后追加写入,加个\n换行就行。

# 要在文件开始位置插入一句话
# file.seek(off, whence)
# whence(0代表文件开始位置,1代表当前位置,2代表文件末尾)偏移off字节
#文章开头介绍过,r+,读写模式,忘了的回到文章开头看
with open('./python_zen_write.txt',mode='r+',encoding='utf-8') as f:
    content=f.read()
    f.seek(0,0)
    f.write('开始位置:python之禅\n'+content)

在这里插入图片描述
试试末尾追加写入

with open('./python_zen_write.txt',mode='r+',encoding='utf-8') as f:
    f.seek(0,2)
    f.write('\n末尾位置:结束语')

在这里插入图片描述

文件和目录操作

使用os库

import os

常用的操作函数

函数说明
getcwd获取当前工作目录,即当前python脚本所在的目录路径
listdir列出指定目录下的所有文件和子目录,包括隐藏文件
mkdir创建目录
unlink删除文件
remove删除文件
rmdir删除空目录
removedirs若目录为空,则删除,并递归到上一级目录,若上一级目录为空,也删除
rename重命名文件
stat获取一个文件的属性及状态信息

os.path可以调用ntpath.py模块

os.path

在这里插入图片描述
常用的操作函数

函数说明
abspath返回规范化的绝对路径
basename返回最后的文件名部分
dirname返回目录部分
split将文件名分割成目录和文件名
splitext分离扩展名
join将多个路径组合起来,以字符串中含有/的第一个路径开始拼接
getctime返回文件或目录的创建(复制到某个目录)的时间
getatime访问时间,读一次文件的内容,这个时间就会更新
getmtime修改时间,修改一次文件的内容,这个时间就会更新
getsize获取文件大小
isabs如果path是绝对路径,返回True
exists如果path存在,则返回True;如果path不存在,则返回False
isdir如果path是一个存在的目录,则返回True,否则返回False
isfile如果path是一个存在的文件,则返回True,否则返回False
os.getcwd()#当前工作目录

在这里插入图片描述

# 修改工作目录
os.chdir('D:\\Anaconda3\\AnacondaProjects')
print(os.getcwd())
os.chdir('D:\\Anaconda3\\AnacondaProjects\\python自动化办公')
print(os.getcwd())

在这里插入图片描述

os.listdir()#获取当前工作目录的全部文件和子目录

在这里插入图片描述

# 遍历文件目录
# os.listdir()方法不能获取子目录里面的文件,
# 要进一步获取则需要用到os.walk方法。
path=r'D:\Anaconda3\AnacondaProjects\python自动化办公'
for foldName,subfolders,filenames in os.walk(path):
    for filename in filenames:
        print(foldName,filename)#foldName文件目录,filename文件名

在这里插入图片描述

# 拆分绝对路径文件名
path=r'D:\Anaconda3\AnacondaProjects\python自动化办公\python_zen.txt'
print(os.path.split(path))
print(os.path.dirname(path))
print(os.path.basename(path))
print(os.path.splitext(path))

在这里插入图片描述

#组合文件名
print(os.path.join(os.getcwd(),os.path.basename(path)))

在这里插入图片描述

# 获取文件属性
path=r'D:\Anaconda3\AnacondaProjects\python自动化办公\python_zen.txt'
print(os.path.getctime(path))#创建时间
print(os.path.getmtime(path))#修改时间
print(os.path.getatime(path))#访问时间

在这里插入图片描述
上述格式的时间表示从1970年1月1日到现在已经经过多少秒,要把它转换成可以理解的时间要使用time模块。

import time
print(time.ctime(os.path.getctime(path)))#创建时间
print(time.ctime(os.path.getmtime(path)))#修改时间
print(time.ctime(os.path.getatime(path)))#访问时间

在这里插入图片描述
这里的创建时间,并不是指这个文件内容的原创时间,如果文件从别处复制过来,那就是复制的时间。

print(os.path.getsize(path))#查看文件大小

在这里插入图片描述

# stat方法获取文件的属性及状态信息
print(os.stat(path))

在这里插入图片描述

# 输出文件大于0且后缀为.txt的文件名
for file in os.listdir():
    path=os.path.abspath(file)
    filesize=os.path.getsize(path)
    if filesize>0 and os.path.splitext(path)[-1]=='.txt':
        print(os.path.basename(path))

在这里插入图片描述
同理,也可以删除符合某些条件的文件os.remove(file)

# 新建一个文本文件
with open('new.txt','w',encoding='utf-8') as f:
    f.write('一个新的txt文件')
for foldName,subfolders,filenames in os.walk(os.getcwd()):
    print('foldName:',foldName,'\n','subfolders:',subfolders,'\n','filenames:',filenames)

在这里插入图片描述

# 将当前目录及子目录所有new.txt文件改名为new2023.txt
for foldName,subfolders,filenames in os.walk(os.getcwd()):
    for filename in filenames:
        #不加这个筛选条件,则是更改所有文件文件名。也可加其他筛选条件
        if filename=='new.txt':
            abspath=os.path.join(foldName,filename)
            extension=os.path.splitext(abspath)[1]
            new_name=filename.replace(extension,'2023'+extension)
            os.rename(abspath,os.path.join(foldName,new_name))

使用shutil库

下篇文章python自动化办公(二)再继续写吧。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/449.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

FreeRTOS系列第1篇---为什么选择FreeRTOS?

1.为什么学习RTOS&#xff1f; 作为基于ARM7、Cortex-M3硬件开发的嵌入式工程师&#xff0c;我一直反对使用RTOS。不仅因为不恰当的使用RTOS会给项目带来额外的稳定性风险&#xff0c;更重要的是我认为绝大多数基于ARM7、Cortex-M3硬件的项目&#xff0c;还没复杂到使用RTOS的地…

【华为机试真题详解 Python实现】最差产品奖【2023 Q1 | 100分】

文章目录 前言题目描述输入描述输出描述示例 1题目解析参考代码前言 《华为机试真题详解》专栏含牛客网华为专栏、华为面经试题、华为OD机试真题。 如果您在准备华为的面试,期间有想了解的可以私信我,我会尽可能帮您解答,也可以给您一些建议! 本文解法非最优解(即非性能…

SpringBoot和Spring AOP默认动态代理方式

SpringBoot和Spring AOP默认动态代理方式 目录SpringBoot和Spring AOP默认动态代理方式1. springboot 2.x 及以上版本2. Springboot 1.x3.SpringBoot 2.x 为何默认使用 CglibSpring 5.x中AOP默认依旧使用JDK动态代理SpringBoot 2.x开始&#xff0c;AOP为了解决使用JDK动态代理可…

做技术,最忌讳东张西望

又好长时间没更新&#xff0c;研二了&#xff0c;忙着做实验、写论文、发论文&#xff0c;再加上给我导做一些事情&#xff08;都习惯了&#xff0c;以前很不爽的事情&#xff0c;现在居然能这么平静的说出来&#xff09;。 但这不是我今天说的重点&#xff0c;而是另外一件事…

【开发工具】idea配置全局变量Jdk、maven仓库、maven(全文图解)

文章目录IDEA配置JDK1、点击File -->Project Structure&#xff1b;2、点击左侧标签页SDKs选项&#xff0c;再点击左上角“”&#xff0c;选择JDK&#xff1b;3、在弹出框选择JDK安装路径&#xff0c;点击OK即可配置成功。配置maven仓库&#xff08;阿里云&#xff09;1、配…

素材要VIP咋整?看python大展神通

前言 嗨喽~大家好呀&#xff0c;这里是魔王呐 ❤ ~! 再我们缺少素材的时候&#xff0c;我们第一反应 我们肯定会去网上寻找&#xff0c;但是&#xff01;&#xff01; 有的素材需要VIP&#xff01;这可咋整呢&#xff1f; 看我利用python大展神通&#xff0c;采集某图网图片…

面试官:关于CPU你了解多少?

CPU是如何执行程序的&#xff1f; 程序执行的基本过程 第一步&#xff0c;CPU 读取「程序计数器」的值&#xff0c;这个值是指令的内存地址&#xff0c;然后 CPU 的「控制单元」操作「地址总线」指定需要访问的内存地址&#xff0c;接着通知内存设备准备数据&#xff0c;数据准…

Altium Designer(AD)软件使用记录11-PCB布线部分之走线

目录Altium Designer(AD)软件使用记录11-PCB布线部分之走线核心-SDRAM-FLASH 模块走线BGA 滤波电容放置处理其他杂线走线清理Altium Designer(AD)软件使用记录11-PCB布线部分之走线 核心-SDRAM-FLASH 模块走线 走线总结&#xff1a; 走线从核心器件部分&#xff0c;线路密度最…

Java——二叉树的最近公共祖先及二叉搜索树介绍

目录 二叉树的最近公共祖先 题目 思路一&#xff1a;如果给定的是一颗二叉搜索树&#xff0c; 思路二&#xff1a;假设是孩子双亲表示法 二叉搜索树 定义Node类 查找 删除 插入 二叉树的最近公共祖先 题目 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。 百度百…

OpenCV入门(十一)快速学会OpenCV 10 形态学操作

OpenCV入门&#xff08;十一&#xff09;快速学会OpenCV 10 形态学操作 作者&#xff1a;Xiou 形态学&#xff0c;即数学形态学&#xff08;Mathematical Morphology&#xff09;&#xff0c;是图像处理过程中一个非常重要的研究方向。 形态学主要从图像内提取分量信息&#…

java入门多线程一文通

一、面试经典 1.为什么使用多线程及其重要 为了使用户体验更好&#xff0c;服务的相应速度更快。现如今硬件不断发展&#xff0c;软件要求也逐渐提高&#xff0c;都是为了一个字&#xff1a;快。 2.进程、线程、管程&#xff08;monitor 监视器&#xff09; 3.多线程并行和…

字符函数和字符串函数(下)——“C”

各位CSDN的uu们你们好呀&#xff0c;今天小雅兰的内容依旧是字符函数和字符串函数呀&#xff0c;这篇博客会讲一些内存相关的函数&#xff0c;下面&#xff0c;让我们进入字符函数和字符串函数的世界吧 字符串查找 strstr strtok 错误信息报告 strerror 字符操作 内存操作函…

微信小程序搭建流程

一、申请微信开发者账号虽然开发微信小程序可以使用工具提供的测试号&#xff0c;但是测试号提供的功能极为有限&#xff0c;而且使用测试号开发的微信小程序不能上架发布。因此说我们想要开发一个可以上架的微信小程序&#xff0c;首先必须要申请微信开发者账号。大家尽可放心…

Python 四大主流 Web 编程框架

目前Python的网络编程框架已经多达几十个&#xff0c;逐个学习它们显然不现实。但这些框架在系统架构和运行环境中有很多共通之处&#xff0c;本文带领读者学习基于Python网络框架开发的常用知识,及目前的4种主流Python网络框架&#xff1a;Django、Tornado、Flask、Twisted。 …

Python带你制作一个属于自己的多功能音乐播放器

前言 嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 就是用Python做一个简易的音乐播放器&#xff0c;废话不多说&#xff0c;咱们直接开干 当然&#xff0c;今天做这个肯定不是最简单的&#xff0c;最简单的音乐播放器&#xff0c;9行代码足以 完整源码等直接在文末名片领…

什么是API?(详细解说)

编程资料时经常会看到API这个名词&#xff0c;网上各种高大上的解释估计放倒了一批初学者。初学者看到下面这一段话可能就有点头痛了。 API&#xff08;Application Programming Interface,应用程序编程接口&#xff09;是一些预先定义的函数&#xff0c;目的是提供应用程序与开…

SpringCloud Alibaba 学习圣经,10万字实现 SpringCloud 自由

40岁老架构师尼恩的掏心窝&#xff1a; 现在拿到offer超级难&#xff0c;甚至连面试电话&#xff0c;一个都搞不到。 尼恩的技术社群中&#xff08;50&#xff09;&#xff0c;很多小伙伴凭借 “左手云原生右手大数据 SpringCloud Alibaba 微服务“三大绝活&#xff0c;拿到了…

内卷把同事逼成了“扫地僧”,把Git上所有面试题整理成足足24W字Java八股文

互联网大厂更多的是看重学历还是技术&#xff1f;毫无疑问&#xff0c;是技术&#xff0c;技术水平相近的情况下&#xff0c;肯定学历高/好的会优先一点&#xff0c;这点大家肯定都理解。说实话&#xff0c;学弟学妹们找工作难&#xff0c;作为面试官招人也难呀&#xff01;&am…

ChatGPT解答:python大批量读写ini文件时,性能很低,有什么解决方法吗,给出具体的思路和实例

ChatGPT解答&#xff1a; python大批量读写ini文件时&#xff0c;性能很低&#xff0c;有什么解决方法吗&#xff0c;给出具体的思路和实例 ChatGPTDemo Based on OpenAI API (gpt-3.5-turbo). python大批量读写ini文件时&#xff0c;性能很低&#xff0c;有什么解决方法吗&…

让ChatGPT介绍一下ChatGPT

申请新必应内测通过了&#xff0c;我在New Bing中使用下ChatGPT&#xff0c;让ChatGPT介绍一下ChatGPT 问题1&#xff1a;帮我生成一篇介绍chatGPT的文章&#xff0c;不少于2000字 回答&#xff1a; chatGPT是什么&#xff1f;它有什么特点和用途&#xff1f; chatGPT是一种…
最新文章