收集的多个ruby遍历文件夹代码实例
程序员文章站
2022-11-15 19:08:35
一、遍历文件夹下所有文件,输出文件名
复制代码 代码如下:
def traverse_dir(file_path)
if fil...
一、遍历文件夹下所有文件,输出文件名
复制代码 代码如下:
def traverse_dir(file_path)
if file.directory? file_path
dir.foreach(file_path) do |file|
if file !="." and file !=".."
traverse_dir(file_path+"/"+file)
end
end
else
puts "file:#{file.basename(file_path)}, size:#{file.size(file_path)}"
end
end
traverse_dir('d:/apache-tomcat')
二、ruby遍历文件夹
复制代码 代码如下:
def get_file_list(path)
dir.entries(path).each do |sub|
if sub != '.' && sub != '..'
if file.directory?("#{path}/#{sub}")
puts "[#{sub}]"
get_file_list("#{path}/#{sub}")
else
puts " |--#{sub}"
end
end
end
end
三、python如何遍历一个目录输出所有文件名
复制代码 代码如下:
#coding=utf-8
'''
created on 2014-11-14
@author: neo
'''
import os
def getfilelist(dir, filelist):
newdir = dir
if os.path.isfile(dir):
filelist.append(dir.decode('gbk'))
elif os.path.isdir(dir):
for s in os.listdir(dir):
#如果需要忽略某些文件夹,使用以下代码
#if s == "xxx":
#continue
newdir=os.path.join(dir,s)
getfilelist(newdir, filelist)
return filelist
list = getfilelist('d:\\workspace\\pydemo\\fas', [])
for e in list:
print e
result:
复制代码 代码如下:
d:\workspace\pydemo\fas\file1\20141113\a.20141113-1100.log
d:\workspace\pydemo\fas\file1\20141113\a.20141113-1101.log
d:\workspace\pydemo\fas\file1\20141113\a.20141113-1140.log
d:\workspace\pydemo\fas\file2\20141113\a.20141113-1100.log
d:\workspace\pydemo\fas\file2\20141113\a.20141113-1101.log
d:\workspace\pydemo\fas\file2\20141113\a.20141113-1140.log
四、简洁遍历写法
复制代码 代码如下:
import os
def iterbrowse(path):
for home, dirs, files in os.walk(path):
for filename in files:
yield os.path.join(home, filename)
for fullname in iterbrowse("/home/bruce"):
print fullname
上一篇: 香椿的分类和营养价值
下一篇: 红枣可以泡酒吗以及功效作用