python 002 文件输入输出
python 文件对象不仅可以访问普通磁盘文件,也可以访问抽象层面上的文件对象(例如URL地址)
打开文件open() file()功能一致可以任意替代
fp = open('/etc/test.txt', 'r') #以只读方式打开
fp = open('test.txt', 'w') #以写方式打开
fp = open('data.txt', 'r+') #以读写方式打开
fp = open(r'c:\io.sys', 'rb') #以二进制只读方式打开
输入:
tp.read(size) #从文件中读取size个字节,默认size是-1表示读取所有内容
tp.readline() #每次只读一行
tp.readlines() #读取指针所在位置后的所有信息
输出:
fp.write('test test')
文件内移动
seek(-12,1) #在当前位置向前移动12个字符
#-12 负号指向前移动 1表示当前位置 0表示文件开始 2表示文件结尾
#使用前需要使用tell()返回当前文件中的位置
#例子
f = open('test.txt','w+')
print f.tell()
f.write('text line 1\n')
print f.tell()
f.write('test line 2\n')
print f.tell()
f.seek(-13,1)
print f.tell()
f.write('test line 3\n')
print f.tell()
f.seek(-13,1)
print f.tell()
对文件进行操作完后一定要记得关闭文件fp.close()
os.stat 查看文件信息
os.utime 更新时间戳
In [22]: import sys , os #导入sys os模块 In [23]: st = os.stat('test.txt') #查看test.txt文件信息 In [24]: print st #打印文件信息
nt.stat_result(st_mode=33206, st_ino=0L, st_dev=0L, st_nlink=0, st_uid=0, st_gid
=0, st_size=26L, st_atime=1497092960L, st_mtime=1497094979L, st_ctime=1497092960
L) In [25]: print 'test.txt的访问时间:%s' % st.st_atime
test.txt的访问时间:1497092960.56 In [26]: print 'test.txt的修改时间:%s' % st.st_mtime
test.txt的修改时间:1497094979.38 In [27]: os.utime('test.txt',(1330712280,1330712292)) #更新test.txt时间戳
创建临时文件对象
tmpfile()
In [31]: tmpfile = os.tmpfile() #创建一个临时文件对象 In [32]: tmpfile.write('临时文件创建成功了') #在文件中写入一句话
In [33]: tmpfile.seek(0) #将文件指针移到文件开始 In [34]: print tmpfile.read() #读取文件信息
临时文件创建成功了 In [35]: tmpfile.close() #关闭文件
生成一个目录树下的所有文件名
walk()
os.walk()遍历文件和目录
import os
for root , dirs , files in os.walk('.',topdown=True):
print root
print dirs
print files
for name in files:
print(os.path.join(root,name))
for name in dirs:
print(os.path.join(root,name)) 输出结果:
.
['.idea', 'ABC', 'BCD']
['filename.py', 'log.log', 'tell.py', 'test.txt', 'walk.py', 'write.py']
.\filename.py
.\log.log
.\tell.py
.\test.txt
.\walk.py
.\write.py
.\.idea
.\ABC
.\BCD
.\.idea
[]
['misc.xml', 'modules.xml', 'untitled.iml', 'workspace.xml']
.\.idea\misc.xml
.\.idea\modules.xml
.\.idea\untitled.iml
.\.idea\workspace.xml
.\ABC
[]
[]
.\BCD
[]
[]
Process finished with exit code 0
目录和文件夹
In [1]: import os In [2]: os.getcwd()
Out[2]: 'C:\\Users\\Administrator\\PycharmProjects\\untitled' In [3]: os.mkdir('BBB') In [4]: os.listdir('.')
Out[4]:
['.idea',
'ABC',
'BBB',
'BCD',
'filename.py',
'log.log',
'tell.py',
'test.txt',
'walk.py',
'write.py'] In [5]: os.rmdir('BBB') In [6]: os.chdir('c:/Users/') In [7]: os.getcwd()
Out[7]: 'c:\\Users'
os.path模块中的路径名访问函数
import os #导入os模块
#去掉目录返回文件名
print os.path.basename('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#去掉文件名,返回路径
print os.path.dirname('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#将各部分拼接成一个路径
print os.path.join('c:\\','dir','abc')
#返回路径和文件名
print os.path.split('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#返回盘符和文件路径
print os.path.splitdrive('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#返回文件名字和扩展名
print os.path.splitext('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#返回最近访问时间
print os.path.getatime('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#返回创建时间
print os.path.getctime('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#返回修改时间
print os.path.getmtime('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#返回文件大小(以字节为单位)
print os.path.getsize('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#判断指定文件或目录是否存在
print os.path.exists('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#判断指定路径是否为绝对路径
print os.path.isabs('C:/Users/Administrator/PycharmProjects/untitled/walk1.py')
#判断指定路径是否为一个目录
print os.path.isdir('C:/Users/Administrator/PycharmProjects/untitled/')
#判断指定路径是否是文件
print os.path.isfile('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#判断指定路径是否是一个链接
print os.path.islink('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#判断指定路径是否是一个挂载点
print os.path.ismount('C:/Users/Administrator/PycharmProjects/untitled/walk.py')
#判断两个路径是否指向同一个文件
print os.path.samefile('C:/Users/Administrator/PycharmProjects/untitled/walk.py','C:/Users/Administrator/PycharmProjects/untitled/walk.py')
输出结果:
walk.py
C:/Users/Administrator/PycharmProjects/untitled
c:\dir\abc
('C:/Users/Administrator/PycharmProjects/untitled', 'walk.py')
('C:', '/Users/Administrator/PycharmProjects/untitled/walk.py')
('C:/Users/Administrator/PycharmProjects/untitled/walk', '.py')
1497103691.58
1497101112.35
1497103691.58
240
True
True
True
True
False
False
python 002 文件输入输出的更多相关文章
- python 中文件输入输出及os模块对文件系统的操作
整理了一下python 中文件的输入输出及主要介绍一些os模块中对文件系统的操作. 文件输入输出 1.内建函数open(file_name,文件打开模式,通用换行符支持),打开文件返回文件对象. 2. ...
- Python的文件输入输出,如何追加内容,读取内容,添加内容
python主要的文件打开的几种访问模式 模式可以为读模式('r').写模式('w')或追加模式('a'),当然还有rb.wb.ab.r+.w+.a+.rb+.wb+.ab+,然而实际从代码上我也没看 ...
- Python之文件输入输出,
文件输入与输出 • 打开文件返回文件对象 – file_object=open(file_name,access_mode='r') • 关闭文件对象 – file_object.close() ...
- Python基础-输入输出(IO)
Python基础-输入输出(IO) 程序会有输入和输出,输入可以从标准输入或是从一个文件读入数据,程序的输出可以以一种友好可读的方式(human-readable)打印出来,或是写进一个文件,而标准输 ...
- Python操作文件-20181121
Python操作文件 Python操作文件和其他语言一样,操作的过程无非是先定位找到文件.打开文件,然后对文件进行操作,操作完成后关闭文件即可. 文件操作方式:对文件进行操作,主要就是读.写的方式,p ...
- 用 Python 实现文件查找
用 Python 实现文件查找(BIF实现及队列实现) (1)利用内置函数实现文件查找 1.功能:返回用户输入的文件的绝对路径 2.设计思路: (1)用户输入在哪个盘进行查找 (2)遍历此盘文件,若为 ...
- Python读写文件
Python读写文件1.open使用open打开文件后一定要记得调用文件对象的close()方法.比如可以用try/finally语句来确保最后能关闭文件. file_object = open('t ...
- python计算文件的md5值
前言 最近要开发一个基于python的合并文件夹/目录的程序,本来的想法是基于修改时间的比较,即判断文件有没有改变,比较两个文件的修改时间即可.这个想法在windows的pc端下测试没有问题. 但是当 ...
- python操作文件案例二则
前言 python 对于文件及文件夹的操作. 涉及到 遍历文件夹下所有文件 ,文件的读写和操作 等等. 代码一 作用:查找文件夹下(包括子文件夹)下所有文件的名字,找出 名字中含有中文或者空格的文件 ...
随机推荐
- Maven+Docker,发布到Registry
1.配置Pom.xml <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEnc ...
- DOM对象之window
window的属性 top:返回当前窗口的最顶层的先辈窗口 document:返回HTML文档对象 location:当前窗口的地址 self:返回对自身窗口的引用 parent:返回父窗口 如何引用 ...
- http服务器与https服务器的区别
1.HTTPS服务器使用的是HTTPS协议,而HTTP使用的是HTTP协议. 2.HTTPS服务器需要向证书授权中心申请证书,一般免费证书很少,需要交费. 3.HTTP服务器与客户端传递的是明文数据, ...
- cesium的学习
一.学习资料:http://cesiumjs.org/tutorials.html,看完6个教程后对图层加载.控件控制开关.地形数据叠加.模型添加.相机控制.图形绘制有一点了解.这也是cesium的主 ...
- Ajax系列面试题总结
1.Ajax是什么?如何创建一个Ajax? Ajax并不算是一种新的技术,全称是asychronous javascript and xml,可以说是已有技术的组合,主要用来实现客户端与服务器端的异步 ...
- 输出n*n矩阵
int matrix[MAX][MAX]; void PrintMatrix(int x,int y,int start,int n) { ) return ; ) { matrix[x][y] = ...
- Linux常用解压缩命令
压 缩:tar -jcv -f filename.tar.bz2 要被压缩的文件或目录名称 查 询:tar -jtv -f filename.tar.bz2 解压缩:tar -jxv -f filen ...
- OSI 7层模型和 TCP/IP 5层模型
网络协议通常分不同层次进行开发,每一层分别负责不同的通行功能. 两种参考模型 OSI 和 TCP/IP, OSI 先有模型后有协议,TCP/IP 则相反. OSI 7层模型 - 应用层 - 表示层 - ...
- 第三节:Web爬虫之BeautifulSoup解析库
Beautiful Soup官方说明: Beautiful Soup提供一些简单的.python式的函数用来处理导航.搜索.修改分析树等功能.它是一个工具箱,通过解析文档为用户提供需要抓取的数据,因为 ...
- Dijkstra算法求最短路径
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <limits.h&g ...