【问题标题】:How to print a dictionary line by line in Python?如何在 Python 中逐行打印字典?
【发布时间】:2013-03-25 00:32:55
【问题描述】:

这是字典

cars = {'A':{'speed':70,
        'color':2},
        'B':{'speed':60,
        'color':3}}

使用这个for loop

for keys,values in cars.items():
    print(keys)
    print(values)

它打印以下内容:

B
{'color': 3, 'speed': 60}
A
{'color': 2, 'speed': 70}

但我希望程序像这样打印它:

B
color : 3
speed : 60
A
color : 2
speed : 70

我刚开始学习字典,所以我不知道该怎么做。

【问题讨论】:

    标签: python printing dictionary


    【解决方案1】:

    使用这个。

    cars = {'A':{'speed':70,
            'color':2},
            'B':{'speed':60,
            'color':3}}
    
    print(str(cars).replace(",", ",\n"))
    

    输出:

    {'A': {'speed': 70,
     'color': 2},
     'B': {'speed': 60,
     'color': 3}}
    

    【讨论】:

      【解决方案2】:

      我更喜欢yaml 的简洁格式:

      import yaml
      print(yaml.dump(cars))
      

      输出:

      A:
        color: 2
        speed: 70
      B:
        color: 3
        speed: 60
      

      【讨论】:

      • 你必须先pip install PyYAML
      • 与上面的 pprint 示例不同,当列表嵌套在 dicts 中时,这似乎会中断。
      • 非常好的和紧凑的解决方案。只需添加print 语句。
      【解决方案3】:

      pprint.pprint() 是完成这项工作的好工具:

      >>> import pprint
      >>> cars = {'A':{'speed':70,
      ...         'color':2},
      ...         'B':{'speed':60,
      ...         'color':3}}
      >>> pprint.pprint(cars, width=1)
      {'A': {'color': 2,
             'speed': 70},
       'B': {'color': 3,
             'speed': 60}}
      

      【讨论】:

      • 这似乎是迄今为止最简单和最好的解决方案,因为它还可以处理嵌套在 中的 sets、tupleslists >dict.
      【解决方案4】:

      这是我对问题的解决方案。我认为它的方法相似,但比其他一些答案要简单一些。它还允许任意数量的子字典,并且似乎适用于任何数据类型(我什至在具有函数作为值的字典上对其进行了测试):

      def pprint(web, level):
          for k,v in web.items():
              if isinstance(v, dict):
                  print('\t'*level, f'{k}: ')
                  level += 1
                  pprint(v, level)
                  level -= 1
              else:
                  print('\t'*level, k, ": ", v)
      

      【讨论】:

      • 我看不出这比其他答案更简单。当然不是为了可读性。也很高兴看到一些示例输出。
      【解决方案5】:

      处理任意深度嵌套的字典和列表的更通用的解决方案是:

      def dumpclean(obj):
          if isinstance(obj, dict):
              for k, v in obj.items():
                  if hasattr(v, '__iter__'):
                      print k
                      dumpclean(v)
                  else:
                      print '%s : %s' % (k, v)
          elif isinstance(obj, list):
              for v in obj:
                  if hasattr(v, '__iter__'):
                      dumpclean(v)
                  else:
                      print v
          else:
              print obj
      

      这会产生输出:

      A
      color : 2
      speed : 70
      B
      color : 3
      speed : 60
      

      我遇到了类似的需求,并开发了一个更强大的功能作为自己的练习。我把它包括在这里,以防它对另一个人有价值。在运行nosetest 时,我还发现能够在调用中指定输出流以便可以使用sys.stderr 来代替它很有帮助。

      import sys
      
      def dump(obj, nested_level=0, output=sys.stdout):
          spacing = '   '
          if isinstance(obj, dict):
              print >> output, '%s{' % ((nested_level) * spacing)
              for k, v in obj.items():
                  if hasattr(v, '__iter__'):
                      print >> output, '%s%s:' % ((nested_level + 1) * spacing, k)
                      dump(v, nested_level + 1, output)
                  else:
                      print >> output, '%s%s: %s' % ((nested_level + 1) * spacing, k, v)
              print >> output, '%s}' % (nested_level * spacing)
          elif isinstance(obj, list):
              print >> output, '%s[' % ((nested_level) * spacing)
              for v in obj:
                  if hasattr(v, '__iter__'):
                      dump(v, nested_level + 1, output)
                  else:
                      print >> output, '%s%s' % ((nested_level + 1) * spacing, v)
              print >> output, '%s]' % ((nested_level) * spacing)
          else:
              print >> output, '%s%s' % (nested_level * spacing, obj)
      

      使用此函数,OP 的输出如下所示:

      {
         A:
         {
            color: 2
            speed: 70
         }
         B:
         {
            color: 3
            speed: 60
         }
      }
      

      我个人认为它更有用且更具描述性。

      给出一个稍微不那么简单的例子:

      {"test": [{1:3}], "test2":[(1,2),(3,4)],"test3": {(1,2):['abc', 'def', 'ghi'],(4,5):'def'}}
      

      OP 请求的解决方案产生了这个:

      test
      1 : 3
      test3
      (1, 2)
      abc
      def
      ghi
      (4, 5) : def
      test2
      (1, 2)
      (3, 4)
      

      而“增强”版本会产生这样的结果:

      {
         test:
         [
            {
               1: 3
            }
         ]
         test3:
         {
            (1, 2):
            [
               abc
               def
               ghi
            ]
            (4, 5): def
         }
         test2:
         [
            (1, 2)
            (3, 4)
         ]
      }
      

      我希望这能为下一个寻找此类功能的人提供一些价值。

      【讨论】:

      • 如果格式不是太严格,也可以使用'print json.dumps(obj, indent=3)'。这给出了大多数结构的合理表示,尽管由于使用元组作为键,它确实(在我的环境中)在我不太平凡的示例中窒息......
      • 为什么不在这里使用pprint.pprint()呢?
      • 差点成为 JSON 创建者,不是吗?
      【解决方案6】:
      # Declare and Initialize Map
      map = {}
      
      map ["New"] = 1
      map ["to"] = 1
      map ["Python"] = 5
      map ["or"] = 2
      
      # Print Statement
      for i in map:
        print ("", i, ":", map[i])
      
      #  New : 1
      #  to : 1
      #  Python : 5
      #  or : 2
      

      【讨论】:

        【解决方案7】:
        ###newbie exact answer desired (Python v3):
        ###=================================
        """
        cars = {'A':{'speed':70,
                'color':2},
                'B':{'speed':60,
                'color':3}}
        """
        
        for keys, values in  reversed(sorted(cars.items())):
            print(keys)
            for keys,values in sorted(values.items()):
                print(keys," : ", values)
        
        """
        Output:
        B
        color  :  3
        speed  :  60
        A
        color  :  2
        speed  :  70
        
        ##[Finished in 0.073s]
        """
        

        【讨论】:

          【解决方案8】:

          修改 MrWonderful 代码

          import sys
          
          def print_dictionary(obj, ident):
              if type(obj) == dict:
                  for k, v in obj.items():
                      sys.stdout.write(ident)
                      if hasattr(v, '__iter__'):
                          print k
                          print_dictionary(v, ident + '  ')
                      else:
                          print '%s : %s' % (k, v)
              elif type(obj) == list:
                  for v in obj:
                      sys.stdout.write(ident)
                      if hasattr(v, '__iter__'):
                          print_dictionary(v, ident + '  ')
                      else:
                          print v
              else:
                  print obj
          

          【讨论】:

          • 你修改了什么?输出是什么?
          【解决方案9】:

          您可以为此使用json 模块。此模块中的 dumps 函数将 JSON 对象转换为格式正确的字符串,然后您可以打印该字符串。

          import json
          
          cars = {'A':{'speed':70, 'color':2},
                  'B':{'speed':60, 'color':3}}
          
          print(json.dumps(cars, indent = 4))
          

          输出看起来像

          { “一种”: { “颜色”:2, “速度”:70 }, “乙”:{ “颜色”:3, “速度”:60 } }

          documentation 还为此方法指定了许多有用的选项。

          【讨论】:

          • true,dict 的内容必须可序列化为 json,但是,此处提供的输出比 pprint.PrettyPrinter 生成的输出要干净得多(例如,人类可读)。特别是在一致缩进和丢弃字符串前缀(例如 u'foo')方面。
          • 我会 print(json.dumps(cars, indent=4, ensure_ascii=False)) 因为否则非 ASCII 字符是不可读的。
          【解决方案10】:

          检查以下单行:

          print('\n'.join("%s\n%s" % (key1,('\n'.join("%s : %r" % (key2,val2) for (key2,val2) in val1.items()))) for (key1,val1) in cars.items()))
          

          输出:

          A
          speed : 70
          color : 2
          B
          speed : 60
          color : 3
          

          【讨论】:

          • 不错,但我尝试将其转换为与sys.modules 一起使用,但我失败了。想试试吗?
          【解决方案11】:
          for x in cars:
              print (x)
              for y in cars[x]:
                  print (y,':',cars[x][y])
          

          输出:

          A
          color : 2
          speed : 70
          B
          color : 3
          speed : 60
          

          【讨论】:

          • 我知道这是旧的,但我认为值得一提的是,如果 cars[x] 是整数,这将不起作用。这不是 OP 所要求的,所以我只是为任何偶然发现此问题的人说它,假设这是一个全面的解决方案。
          • @DarrelHolt 你知道如何让它与整数一起工作吗?因为这就是我目前面临的问题
          • @theprowler 最接近重现问题的方法是如果cars = {1:4, 2:5} 然后cars[x] 是映射到键x 的整数,而不是映射到键x 的集合。在这种情况下,您不需要使用 for y in cars[x]: 行,因为您要检索的只有一个值,除非您使用的是列表或整数集之类的东西,否则它应该可以工作。抱歉,已经几个月了,所以我不完全记得我是如何得出上一条评论的结论的。你可以把你的代码发给我,我看看能不能帮到你。
          • 嗯。我认为我的问题比这更糟糕。基本上,我已经从 HTML 表中解析出一些数据,并且碰巧将其存储在字典中,现在我试图将字典数据放入 DataFrame 中,然后再将其全部导出到 Oracle 表中。 ...我知道这很深入,但是现在阻碍我的步骤是将数据放入 DataFrame ....我的字典出于某种原因有一个键,所有数据都在值中,所以很难试图把它整齐地放入行和列中。..
          【解决方案12】:

          如果您知道树只有两个级别,这将起作用:

          for k1 in cars:
              print(k1)
              d = cars[k1]
              for k2 in d
                  print(k2, ':', d[k2])
          

          【讨论】:

            【解决方案13】:
            for car,info in cars.items():
                print(car)
                for key,value in info.items():
                    print(key, ":", value)
            

            【讨论】:

              【解决方案14】:

              你有一个嵌套结构,所以你也需要格式化嵌套字典:

              for key, car in cars.items():
                  print(key)
                  for attribute, value in car.items():
                      print('{} : {}'.format(attribute, value))
              

              打印出来:

              A
              color : 2
              speed : 70
              B
              color : 3
              speed : 60
              

              【讨论】:

                猜你喜欢
                • 1970-01-01
                • 1970-01-01
                • 1970-01-01
                • 1970-01-01
                • 1970-01-01
                • 2011-10-17
                • 1970-01-01
                • 1970-01-01
                • 2020-08-13
                相关资源
                最近更新 更多