如何字典文件夹



我必须创建一个函数来将示例1转换为示例2。我已经做了一个函数,例如1。我如何使一个函数,例如2,嵌套的读出和它们的大小在括号和换行符?

示例1

.

{
       'delo' : {
          'navodila.docx' : 83273,
          'poročilo.pdf' : 37653347,
        },
       'igre' : {},
       'seznam.txt' : 7632,
       'razno' : {
          'slika.jpg' : 4275,
          'prijatelji' : {
             'janez.jpg' : 8734765,
   }
示例2

.

delo 
   navodila.docx (83273)
   poročilo.pdf (37653347)
   artikli.dat (253)
igre
seznam.txt (7632)
razno
   slika.jpg (4275)
   prijatelji
      janez.jpg (8734765)

我已经为第一个例子创建了函数,除了没有换行符:

import os
def f(folder):
    dict={}
    list = os.listdir(folder)
    for ts in list:
        fullName = folder + '\' + ts
        if os.path.isfile(fullName):
            size=os.path.getsize(fullname)
            dict[ts]=size
        else:
            dict[ts]=f(fullName)
        return (dict)
def dump(d, level=0, indent=4):
    for name in d:
        if isinstance(d[name], dict):
            print('{0}{1}'.format(' ' * level, name))
            dump(d[name], level+indent)
        else:
            print('{0}{1} ({2})'.format(' ' * level, name, d[name]))

这就是我真正想要的,一个更简单的方法,只是重新填充

def f(map,n=0): 
        dictionary=beforeF(map) #function before i made
        for key in dictionary.keys():
            fullName = map + '\' + key
            if path.isdir(fullName): 
                print(n*'t'+key+':')
                f(fullName, n+1)
            else:
                print(n*'t'+key + ' (' + str(dictionary[key])+ ')')

我相信这将解决问题。主要思想是相同的,除了必须递归地打印结构,记住缩进并在调用函数时传递它。

你的第一个版本的代码需要一个小的更正,在返回语句的缩进是一个标签太大。此外,只有advice、list和dict是变量名的糟糕选择,因为它们已经内置在类型中。

import os
def f(folder):
    mape={}
    sez = os.listdir(folder)
    for ts in sez:
#        if ts == "." or ts == "..": continue
        fullName = folder + '/' + ts
        if os.path.isfile(fullName):
            size=os.path.getsize(fullName)
            mape[ts]=size
        else:
            mape[ts]=f(fullName)
    return (mape)
struktura = f('.')
def output(tree, zam=0):
    for i in tree:
        if isinstance(tree[i], (int, long)):
            print "{0}{1} ({2})".format(' '*zam*4, i, tree[i])
        else:
            print ' '*zam*4+i
            output(tree[i],zam+1)
output(struktura)

输出函数自然会按照您的要求进行打印。我希望这有助于解决你的问题。

PS: Kakšne udne doma e naloge mate to?…

最新更新