用Python遍历文件,并将结果集存储为xml
2012-02-03 09:45
363 查看
昨天有个需求,要获取服务器某个目录下的某些类型的文件,考虑到服务器即有Linux、又有Windows,所以写了一个Python小程序来完成这项工作。
Linux服务器有CentOS、Fedora等,都预先安装了Python,版本从2.4到2.5不等,而Windows类型的服务器也多数安装了Python,因此只要在本机写好一个脚本,上传到对应机器,在运行时修改参数即可。
Python操作文件和文件夹使用的是os库,下面的代码中主要用到了几个函数:
os.listdir:列出目录下的文件和文件夹
os.path.join:拼接得到一个文件/文件夹的全路径
os.path.isfile:判断是否是文件
os.path.splitext:从名称中取出一个子部分
下面是目录操作的代码
在返回文件的各种信息时,使用自定义类allfile来保存文件的信息,在程序中只用到了文件的全路径,如果需要同时记录文件的大小、时间、类型等信息,可以仿照代码进行扩充。
得到存储文件信息的数组后,还可以将其另存成xml格式,下面是代码,在使用时,需要从Document中导入xml.dom.minidom
下面是保存为xml的代码
执行的代码如下
在Linux命令行状态下,执行Python filesearch.py,便可以生成名为folder.xml的文件。
如果要在Windows中运行该程序,需要把folder变量改成Windows下的格式,例如c:\\apache2\htdocs,然后执行c:\python25\python.exe filesearch.py(这里假设python的安装目录是c:\python25)
所有程序可以在这里下载:源程序
Linux服务器有CentOS、Fedora等,都预先安装了Python,版本从2.4到2.5不等,而Windows类型的服务器也多数安装了Python,因此只要在本机写好一个脚本,上传到对应机器,在运行时修改参数即可。
Python操作文件和文件夹使用的是os库,下面的代码中主要用到了几个函数:
os.listdir:列出目录下的文件和文件夹
os.path.join:拼接得到一个文件/文件夹的全路径
os.path.isfile:判断是否是文件
os.path.splitext:从名称中取出一个子部分
下面是目录操作的代码
def search(folder, filter, allfile): folders = os.listdir(folder) for name in folders: curname = os.path.join(folder, name) isfile = os.path.isfile(curname) if isfile: ext = os.path.splitext(curname)[1] count = filter.count(ext) if count>0: cur = myfile() cur.name = curname allfile.append(cur) else: search(curname, filter, allfile) return allfile
在返回文件的各种信息时,使用自定义类allfile来保存文件的信息,在程序中只用到了文件的全路径,如果需要同时记录文件的大小、时间、类型等信息,可以仿照代码进行扩充。
class myfile: def __init__(self): self.name = ""
得到存储文件信息的数组后,还可以将其另存成xml格式,下面是代码,在使用时,需要从Document中导入xml.dom.minidom
下面是保存为xml的代码
def generate(allfile, xml): doc = Document() root = doc.createElement("root") doc.appendChild(root) for myfile in allfile: file = doc.createElement("file") root.appendChild(file) name = doc.createElement("name") file.appendChild(name) namevalue = doc.createTextNode(myfile.name) name.appendChild(namevalue) print doc.toprettyxml(indent="") f = open(xml, 'a+') f.write(doc.toprettyxml(indent="")) f.close()
执行的代码如下
if __name__ == '__main__': folder = "/usr/local/apache/htdocs" filter = [".html",".htm",".php"] allfile = [] allfile = search(folder, filter, allfile) len = len(allfile) print "found: " + str(len) + " files" xml = "folder.xml" generate(allfile, xml)
在Linux命令行状态下,执行Python filesearch.py,便可以生成名为folder.xml的文件。
如果要在Windows中运行该程序,需要把folder变量改成Windows下的格式,例如c:\\apache2\htdocs,然后执行c:\python25\python.exe filesearch.py(这里假设python的安装目录是c:\python25)
所有程序可以在这里下载:源程序
相关文章推荐
- python文件目录遍历保存成xml文件代码
- python目录操作之python遍历文件夹后将结果存储为xml
- python将xml xsl文件生成html文件存储示例讲解
- python将xml xsl文件生成html文件存储示例讲解
- python目录操作之python遍历文件夹后将结果存储为xml
- [Head First Python]4.读取文件datafile.txt, 去除两边空格, 存储到列表,从列表格式化(nester.py)后输出到文件man.out,other.out
- python操作xml文件详细介绍
- python生成xml文件
- python 遍历目录下文件
- python网络爬虫-数据存储之媒体文件
- Python-遍历目标文件夹下所有文件
- python递归遍历文件夹检查文件
- 使用Xml文件格式存储数据
- 遍历c cpp文件 python 脚本
- 将表/查询存储为标准的XML文件
- Python(13) python解析xml文件
- python遍历文件夹下的文件
- python 读xml文件
- 用Python遍历文件
- 二叉树的基本性质、存储方式与遍历(Python实现)