ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

001_sorted

2022-07-04 00:31:07  阅读:160  来源: 互联网

标签:11 10 20 14 para ... 001 sorted


 

 

if __name__ == '__main__':
    s = "德国 10 11 16\n意大利 10 10 20\n荷兰 10 12 14\n法国 10 12 11\n英国 22 21 22\n中国 38 32 18\n日本 27 14 17\n美国 39 41 33\n俄罗斯奥委会 20 28 23\n澳大利亚 17 7 22\n匈牙利 6 7 7\n加拿大 7 6 11\n古巴 7 3 5\n巴西 7 6 8\n新西兰 7 6 7"

    # 1 国家划分: 字符串切片
    stodata = s.split("\n")  # ['德国 10 11 16', '意大利 10 10 20', '荷兰 10 12 14']

    # 2 重组字典: 数据格式 - {"国家":[奖牌]}
    para = {}
    for line in range(len(stodata)):
        data = stodata[line].split(' ')             # ['德国', '10', '11', '16'] ['意大利', '10', '10', '20'] ['荷兰', '10', '12', '14'] ...
        para[data[0]] = [int(i) for i in data[1:]]  # {'德国': [10, 11, 16], '意大利': [10, 10, 20], '荷兰': [10, 12, 14], ...}
    print(para)

    # 3 字典排序: 奖牌数量
    new_para = sorted(para.items(), key=lambda x: (x[1], x[0]), reverse=True)  # x[1]: 奖牌数量; x[0]国家
    print("new_para:", new_para)                                               # [('美国', [39, 41, 33]), ('中国', [38, 32, 18]), ('日本', [27, 14, 17]), ...]

    # 4 获取名单: 国家
    c = []
    for i in new_para:
        c.append(i[0])  # ['美国', '中国', '日本', ...]

    # 4 打印名词: 字符串拼接
    for j in range(15):
        print(f"{(j + 1):2d} {c[j]}")  #  1 美国  2 中国   3 日本 ...

'''
result
     1 美国
     2 中国
     3 日本
     4 ....
'''


'''
知识:
    # 字符串: 切片
    # 字典:  
        重组格式: {key:list}; 
        推导式: for i in data[1:]
        类型转换: int()
    # sorted
        匿名函数
        排序: 降序
'''

 

标签:11,10,20,14,para,...,001,sorted
来源: https://www.cnblogs.com/huafan/p/16441417.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有