繁体   English   中英

Python:右对齐和有序字典

[英]Python: right justified and ordered dict

以下是我的代码:

inv = {'rope': 1, 'torch': 6, 'gold coin': 42, 'dagger': 1}

x=max(inv, key=lambda x: len(x.split()))
y=len(x)

#print(y)

n = "-"

q = n * (y+5)

#print(q)
#print("")

def print_table(inventory, order=None):

    if order=="count,asc":
        for key, value in sorted(inventory.iteritems(), key=lambda (k, v): (v, k)):
            print "%s %s" % (value, key)

print_table(inv,"count,asc")

我想要这样的东西:

Inventory:
 count    item name
   ----------------
    45    gold coin
    12        arrow
     6        torch
     2       dagger
     1         rope
     1         ruby
    ----------------
  Total number of items: 67

Order参数必须是字符串,其工作方式如下:空(默认情况下)表示表是无序的"count,desc"表是按(清单中项目的数量)降序排列,而"cound,asc"排列订购

我编写了在每个内部列表中找到最长字符串的函数,以知道适合所有字符串的列的宽度,但是现在我被困在这一点上,我现在该怎么办?

您有正确的想法来找到最长的钥匙及其长度。 您所需要做的就是格式化它:

def print_table(inventory, order=None):
    longest_key = max(inventory, key=len)
    max_width = len(longest_key)

    if order == "count,asc":
        for key, value in sorted(inventory.iteritems(), key=lambda (k, v): (v, k)):
            print '%6d %*s' % (value, max_width, key)

输出:

     1    dagger
     1      rope
     6     torch
    42 gold coin

更新

为了解决不同的排序列和顺序(升序,降序),我建议不要传递字符串,而要传递键函数和排序方向(升序或降序):

def print_table(inventory, order=None, descending=False):
    longest_key = max(inventory, key=len)
    max_width = len(longest_key)

    for key, value in sorted(inventory.iteritems(), key=order, reverse=descending):
        print '%6d %*s' % (value, max_width, key)

# Define a bunch of key functions, used for sorting
by_count = lambda (k, v): (v, k)
by_name = None

inv = {'rope': 1, 'torch': 6, 'gold coin': 42, 'dagger': 1}

print '\nBy count, ascending'
print_table(inv, order=by_count)

print('\nBy name, descending')
print_table(inv, order=by_name, descending=True)

注意:默认情况下, sorted函数将按(k,v)对dict.items()进行排序,因此by_name函数可以是None ,也可以是更明确的lambda (k, v): (k, v)

如果这是您要尝试的事情,

reverse=True您的排序方法中的reverse=True可以!

def print_table(inventory, order=None):    
    if order=="count,asc":
        for key, value in sorted(inventory.iteritems(), key=lambda (k, v): (v, k)):
            print str(value).rjust(10), key.rjust(10)
    elif order=="count,desc":
        for key, value in sorted(inventory.iteritems(), key=lambda (k, v): (v, k), reverse=True):
            print str(value).rjust(10), key.rjust(10)

print_table(inv,"count,desc")

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM