これが出発点です。
dirs = %w(Downloads)
Hash[ dirs.map{ |dir| [dir, Dir.glob("#{dir}/*")] } ]
結果は次のとおりです。
{"Downloads"=> ["Downloads/jquery-ui-1.9.1.custom.zip", ... ] }
コードを改良して再帰的にし、配列の結果からフォルダー名を削除することができます...これは再帰的な実装の例です。
class Dir
def self.ls_r(dir)
Hash[ dir,
entries(dir).reject{ |entry| %w(. ..).include?(entry) }.map do |entry|
entry_with_dir = File.join(dir, entry)
File.directory?(entry_with_dir) ? ls_r(entry_with_dir) : entry
end ]
end
end
puts Dir.ls_r('~/Downloads').inspect
#=> { "Downloads" => ["file1", {"Downloads/folder1"=>["subfile1"], ... ] } ... }
再帰では、子フォルダーのキーがそれぞれの親キーに対して相対的である必要があることを考慮していないため、これは最適な実装ではないことに注意してください。この問題を解決するには、この情報を再帰を通じて維持する必要があります。
class Dir
def self.ls_r(dir, key_as_last_path_component = false)
Hash[ (key_as_last_path_component ? File.split(dir).last : dir),
entries(dir).reject{ |entry| %w(. ..).include?(entry) }.map do |entry|
entry_with_dir = File.join(dir, entry)
File.directory?(entry_with_dir) ? ls_r(entry_with_dir, true) : entry
end ]
end
end
puts Dir.ls_r('~/Downloads').inspect
#=> { "Downloads" => ["file1", {"folder1"=>["subfile1"], ... ] } ... }
これで、子フォルダーは親キーを基準にしています。