Python open读写文件实现脚本

简介:

1.open

使用open打开文件后一定要记得调用文件对象的close()方法。比如可以用try/finally语句来确保最后能关闭文件。

1 file_object = open('thefile.txt')
2 try:
3   all_the_text = file_object.read( )
4 finally:
5   file_object.close( )

注:不能把open语句放在try块里,因为当打开文件出现异常时,文件对象file_object无法执行close()方法。

2.读文件

读文本文件

1 input = open('data''r')
2 #第二个参数默认为r
3 input = open('data')

读二进制文件

input = open('data', 'rb')

读取所有内容

1 file_object = open('thefile.txt')
2 try:
3   all_the_text = file_object.read( )
4 finally:
5   file_object.close( )

读固定字节

1 file_object = open('abinfile''rb')
2 try:
3   while True:
4     chunk = file_object.read(100)
5     if not chunk:
6       break
7     do_something_with(chunk)
8 finally:
9   file_object.close( )

读每行

list_of_all_the_lines = file_object.readlines( )

如果文件是文本文件,还可以直接遍历文件对象获取每行:

for line in file_object:
    process line

3.写文件

写文本文件
output = open('data', 'w')

写二进制文件
output = open('data', 'wb')

追加写文件
output = open('data', 'w+')

写数据

1 file_object = open('thefile.txt''w')
2 file_object.write(all_the_text)
3 file_object.close( )

写入多行
file_object.writelines(list_of_text_strings)

注意,调用writelines写入多行在性能上会比使用write一次性写入要高。

在Python一般都是运用内置函数open()与文件进行交互,下面说说具体用法


>>> import os

>>> os.getcwd()    #查看当前工作目录

'C:\\Python33'

>>> os.chdir('C:/Python33/HeadFirstPython/chapter3')   #切换包含数据文件的文件夹

>>> os.getcwd()     #查看切换后的工作目录

'C:\\Python33\\HeadFirstPython\\chapter3'




>>> data=open('sketch.txt')

>>> print(data.readline(),end='')

Man: Is this the right room for an argument?

>>> print(data.readline(),end='')

Other Man: I've told you once.




import os

print(os.getcwd())

os.chdir('C:\Python33\HeadFirstPython\chapter3')

man=[]    #定义列表man接收Man的内容

other=[]  #定义列表other接收Other Man的内容  

 try:

    data=open("sketch.txt")

    for each_line in data:

        try:

            (role, line_spoken)=each_line.split(':', 1)

            line_spoken=line_spoken.strip()

            if role=='Man':

                man.append(line_spoken)

            elif role=='Other Man':

                other.append(line_spoken)

        except ValueError:

                pass

    data.close()

except IOError:

    print('The datafile is missing!')

print (man)

print (other)

 

使用open()方法打开磁盘文件时,默认的访问模式为r,表示读,不需要特意指定;

要打开一个文件完成写,需要指定模式w,如data=open("sketch.txt","w"),如果该文件已经存在则会清空现有内容

要追加到一个文件,需要指定模式a,不会清空现有内容

要打开一个文件完成写和读,且不清空现有内容,需要指定模式w+;











本文转自 chengxuyonghu 51CTO博客,原文链接:http://blog.51cto.com/6226001001/1542653,如需转载请自行联系原作者
目录
相关文章
|
25天前
|
安全 网络安全 文件存储
思科设备巡检命令Python脚本大集合
【10月更文挑战第18天】
62 1
思科设备巡检命令Python脚本大集合
|
21天前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
120 68
|
5天前
|
存储 Python
Python自动化脚本编写指南
【10月更文挑战第38天】本文旨在为初学者提供一条清晰的路径,通过Python实现日常任务的自动化。我们将从基础语法讲起,逐步引导读者理解如何将代码块组合成有效脚本,并探讨常见错误及调试技巧。文章不仅涉及理论知识,还包括实际案例分析,帮助读者快速入门并提升编程能力。
23 2
|
7天前
|
运维 监控 Python
自动化运维:使用Python脚本简化日常任务
【10月更文挑战第36天】在数字化时代,运维工作的效率和准确性成为企业竞争力的关键。本文将介绍如何通过编写Python脚本来自动化日常的运维任务,不仅提高工作效率,还能降低人为错误的风险。从基础的文件操作到进阶的网络管理,我们将一步步展示Python在自动化运维中的应用,并分享实用的代码示例,帮助读者快速掌握自动化运维的核心技能。
19 3
|
12天前
|
缓存 运维 NoSQL
python常见运维脚本_Python运维常用脚本
python常见运维脚本_Python运维常用脚本
17 3
|
12天前
|
数据采集 JSON 数据安全/隐私保护
Python常用脚本集锦
Python常用脚本集锦
15 2
|
13天前
|
运维 监控 应用服务中间件
自动化运维:如何利用Python脚本提升工作效率
【10月更文挑战第30天】在快节奏的IT行业中,自动化运维已成为提升工作效率和减少人为错误的关键技术。本文将介绍如何使用Python编写简单的自动化脚本,以实现日常运维任务的自动化。通过实际案例,我们将展示如何用Python脚本简化服务器管理、批量配置更新以及监控系统性能等任务。文章不仅提供代码示例,还将深入探讨自动化运维背后的理念,帮助读者理解并应用这一技术来优化他们的工作流程。
|
14天前
|
运维 监控 Linux
自动化运维:如何利用Python脚本优化日常任务##
【10月更文挑战第29天】在现代IT运维中,自动化已成为提升效率、减少人为错误的关键技术。本文将介绍如何通过Python脚本来简化和自动化日常的运维任务,从而让运维人员能够专注于更高层次的工作。从备份管理到系统监控,再到日志分析,我们将一步步展示如何编写实用的Python脚本来处理这些任务。 ##
|
1月前
|
Linux 区块链 Python
Python实用记录(十三):python脚本打包exe文件并运行
这篇文章介绍了如何使用PyInstaller将Python脚本打包成可执行文件(exe),并提供了详细的步骤和注意事项。
51 1
Python实用记录(十三):python脚本打包exe文件并运行
|
19天前
|
JSON 测试技术 持续交付
自动化测试与脚本编写:Python实践指南
自动化测试与脚本编写:Python实践指南
24 1