设为首页 收藏本站
查看: 1606|回复: 0

[经验分享] python学习笔记八:文件与目录

[复制链接]

尚未签到

发表于 2015-11-30 14:34:00 | 显示全部楼层 |阅读模式
一、文件的打开和创建
  1、打开
  open(file,mode):



>>>fo = open('test.txt', 'r')
>>>fo.read()
'hello\n'
>>>fo.close()
  file(file,mode):



>>>f = file('test.txt', 'r')
>>>f.read()
'hello\n'
>>>f.close()
  mode可取值:
DSC0000.jpg
  2、创建
  用w/w+/a/a+模式打开即可。

二、文件的读取
  1、String = FileObject.read([size])



>>> fr = open('test.txt')
>>> fr.read()
'hello\nworld\n'
  or:



>>> for i in open('test.txt'):
...     print i
...
hello
world
  2、String = FileObject.readline([size])



>>> f = open('test.txt')
>>> f.readline()
'hello\n'
>>> f.readline()
'world\n'
>>> f.readline()
''
  或者可以用next
  3、List = FileObject.readlines([size])



>>> f = open('test.txt')
>>> f.readlines()
['hello\n', 'world\n']
三、文件的写入
  1、write(string)



>>> f = open('test.txt', 'a')
>>> f.write('hello\nworld')
#'hello\nworld'
  2、writelines(list)



>>> l = ['a','b','c']
>>> f=open('test.txt','a')
>>> f.writelines(l)
#'hello\nworldabc'
  注:writelines相当于调用了多次write,不会自动添加换行(\n)符

四、内容查找替换
  1、FileObject.seek(offset, mode)
  offset:偏移量
  mode:0表示将文件指针指向从文件头部到“偏移量”字节处,
  1表示将文件指针指向从文件当前位置向后移动“偏移量”字节,
  2表示将文件指针指向从文件尾部向前移动“偏移量”字节。



>>> f=open('test.txt')
>>> f.read()
'hello\nworldabc'
>>> f.read()
''
>>> f.seek(0,0)
>>> f.read()
'hello\nworldabc'
>>> f.close()
  2、flush:提交更新,即在文件关闭之前把内存中的内容强制写入文件(一般是文件关闭后写入)
  3、文件查找:遍历行进行查找



#!/usr/bin/python
import re
search='hello world'
file='test.txt'
count = 0
f = open(file)
for l in f.readlines():
li = re.findall(search,l)
if len(li) > 0:
count += len(li)
print "Search " + str(count) + " \"" + search + "\""
f.close()
  4、文件内容替换:遍历行进行替换
  替换到新文件demo:



#!/usr/bin/python

os='hello'
of='test.txt'
rs='ten'
rf='test2.txt'
ofh = open(of)
newl=[]
for l in ofh.readlines():
nl = l.replace(os,rs)
newl.append(nl)
rfh = open(rf,'w+')
rfh.writelines(newl)
ofh.close()
rfh.close()
  替换到原文件demo:



[server@localserver file]$ cat test.txt
abc
hello
world
hello world
helloworld
hello hello world
[server@localserver file]$ cat fr.py
#!/usr/bin/python

os='hello'
file='test.txt'
rs='ten'
f = open(file, 'r+')
s=f.read()
f.seek(0,0)
f.close()
f = open(file, 'w+')
f.write(s.replace(os,rs))
f.close()
[server@localserver file] python fr.py
[server@localserver file]$ cat test.txt
abc
ten
world
ten world
tenworld
ten ten world
  这里采用了重建文件的办法。
  或用 fileinput 模块直接在原文件上修改:



#!/usr/bin/python
import fileinput
os='hello'
file='test.txt'
rs='ten'
for line in fileinput.input(file, inplace=True):
print line.replace(os,rs).replace('\n','')
  注意,这里删除了\n是因为print时会写入换行。

五、文件及目录操作
  一般是借助OS模块实现
  1、mkdir(path[,mode=0777]):创建目录,相当于mkdir



>>>import os
>>>os.mkdir('tt')
  2、makedirs(name[, mode=511]):创建多级目录,相当于mkdir -p
  3、rmdir(path):删除目录,相当于rm
  4、removedirs(path):删除多级目录,相当于rm -rf
  5、listdir(path):列出目录中文件和文件夹,相当于ls
  6、getcwd():获取当前路径,相当于pwd
  7、chdir(path):切换目录,相当于cd
  8、rename(src, dst):重命名
  9、shutil.copyfile(str,dst):复制文件(要引入shutil模块)
  10、path.splitext(filename):获取文件路径和扩展名



>>> import os
>>> fileName, fileExtension = os.path.splitext('/path/to/somefile.ext')
>>> fileName
'/path/to/somefile'
>>> fileExtension
'.ext'
  11、walk(top, topdown=True, onerror=None):遍历目录



>>> import os
>>> g = os.walk('a')
>>> g.next()
('a', ['b'], [])
>>> g.next()
('a/b', ['f', 'c'], [])
>>> g.next()
('a/b/f', [], ['3.txt'])
>>> g.next()
('a/b/c', ['d', 'e'], [])
>>> g.next()
('a/b/c/d', [], ['1.txt'])
>>> g.next()
('a/b/c/e', [], ['2.txt'])
  walk返回的是一个生成器,生成器中的内容是:当前目录,目录列表,文件列表
  python自己递归实现文件遍历:



#!/usr/bin/python
import os
def dirList(path):
filelist = os.listdir(path)
fpath = os.getcwd()
allfile = []
for filename in filelist:
filepath = os.path.abspath(os.path.join(path, filename))
if os.path.isdir(filepath):
allfile.extend(dirList(filepath))
else:
allfile.append(filepath)
return allfile
files = dirList('a')
print files

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-145459-1-1.html 上篇帖子: python提取隐含结构的字符串 下篇帖子: Python开发入门与实战3-Django动态页面
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表