后端开发|Python教程
Python,文件,目录
后端开发-Python教程
A、文件的打开和创建
delphi 计算器源码下载,vscode默认gbk大克,ubuntu输入指令,jar包解压tomcat,有的爬虫作茧自缚,php重新加载页面,黄冈本地seo推广哪家好,地产flash网站,免费dedecms模板下载lzw
1、打开
酒商城源码,vscode右键打开,ubuntu重新编译内核命令,tomcat请求无效,VS中使用sqlite,qq浏览器html5插件下载图片大小,前端热门框架,爬虫获取不到页码,学生管理系统 php,优秀seo平台seo顾问,买源代码的网站,网页授权系统,乐器网站模板,js页面条状,oracle库存管理系统,微信小程序 模板用别的公司后台lzw
复制代码 代码如下:
08wap小说源码,ubuntu编程在哪写,tomcat8支持静态资源,砖头下面的爬虫,php稳定版本免费正式版,seo ppt制作lzw
open(file,mode):
>>>fo = open( est.txt, )
>>>fo.read()
hello\n
>>>fo.close()
file(file,mode):
>>>f = file( est.txt, )
>>>f.read()
hello\n
>>>f.close()
mode可取值:
2、创建
用w/w+/a/a+模式打开即可。
B、文件的读取
1、String = FileObject.read([size])
复制代码 代码如下:
>>> fr = open( est.txt)
>>> fr.read()
hello\nworld\n
or:
复制代码 代码如下:
>>> for i in open( est.txt):
...print i
...
hello
world
2、String = FileObject.readline([size])
复制代码 代码如下:
>>> f = open( est.txt)
>>> f.readline()
hello\n
>>> f.readline()
world\n
>>> f.readline()
\
或者可以用next
3、List = FileObject.readlines([size])
复制代码 代码如下:
>>> f = open( est.txt)
>>> f.readlines()
[hello\n, world\n]
C、文件的写入
1、write(string)
复制代码 代码如下:
>>> f = open( est.txt, a)
>>> f.write(hello\nworld)
#hello\nworld
2、writelines(list)
复制代码 代码如下:
>>> l = [a,,c]
>>> f=open( est.txt,a)
>>> f.writelines(l)
#hello\nworldabc
注:writelines相当于调用了多次write,不会自动添加换行(\n)符
D、内容查找替换
1、FileObject.seek(offset, mode)
offset:偏移量
mode:
0表示将文件指针指向从文件头部到“偏移量”字节处,
1表示将文件指针指向从文件当前位置向后移动“偏移量”字节,
2表示将文件指针指向从文件尾部向前移动“偏移量”字节。
复制代码 代码如下:
>>> f=open( est.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= est.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= est.txt
rs= en
rf= est2.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= est.txt
rs= en
f = open(file, +)
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= est.txt
rs= en
for line in fileinput.input(file, inplace=True):
print line.replace(os,rs).replace(\ ,\)
注意,这里删除了\n是因为print时会写入换行。
E、文件及目录操作
一般是借助OS模块实现
1、mkdir(path[,mode=0777]):创建目录,相当于mkdir
复制代码 代码如下:
>>>import os
>>>os.mkdir( t)
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, [], [])
>>> 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