zoukankan      html  css  js  c++  java
  • 嵌套元组拆包及具名元组

    接受表达式的元组可以是嵌套式的,例如 (a, b, (c, d))。只要这个 接受元组的嵌套结构符合表达式本身的嵌套结构,Python 就可以作出正 确的对应。

    用嵌套元组来获取经度:

    metro_areas = [
    ('Tokyo','JP',36.933,(35.689722,139.691667)), #
    ('Delhi NCR', 'IN', 21.935, (28.613889, 77.208889)),
    ('Mexico City', 'MX', 20.142, (19.433333, -99.133333)),
    ('New York-Newark', 'US', 20.104, (40.808611, -74.020386)),
    ('Sao Paulo', 'BR', 19.649, (-23.547778, -46.635833)),
    ]
    print('{:15} | {:^9} | {:^9}'.format('', 'lat.', 'long.'))      # 格式化输出, :后面表示条件 :15即表示占用15个长度字符位置 :^9表示占用9个字符长度,并居中
    fmt = '{:15} | {:9.4f} | {:9.4f}'                               # .4f 表示取浮点数后四位
    for name, cc, pop, (latitude, longitude) in metro_areas: #
    if longitude <= 0: #
    print(fmt.format(name, latitude, longitude))

    ❶ 每个元组内有 4 个元素,其中最后一个元素是一对坐标。

    ❷ 我们把输入元组的最后一个元素拆包到由变量构成的元组里,这样 就获取了坐标。

    ❸ if longitude <= 0: 这个条件判断把输出限制在西半球的城市。

    output:

                    |        lat.      |        long.
    Mexico City     |      19.4333     |      -99.1333
    New York-Newark |      40.8086     |      -74.0204
    Sao Paul        |      -23.5478    |      -46.6358
    积一时之跬步,臻千里之遥程
  • 相关阅读:
    二分查找
    Uva11464 Even Parity
    Uva10881 Piotr's Ants
    POJ3154 Graveyard
    [NOIP2015] 提高组 洛谷P2680 运输计划
    [NOIP2015] 提高组 洛谷P2679 子串
    [NOIP2015] 提高组 洛谷P2678 跳石头
    [NOIP2015] 提高组 洛谷P2668 斗地主
    [NOIP2015] 提高组 洛谷P2661 信息传递
    [NOIP2015] 提高组 洛谷P2615 神奇的幻方
  • 原文地址:https://www.cnblogs.com/wangbaojun/p/10622762.html
Copyright © 2011-2022 走看看