• 第012讲:列表:一个打了激素的数组3


    0. 注意,这道题跟上节课的那道题有点儿不同,回答完请上机实验或参考答案。

    old = [1, 2, 3, 4, 5]
    new = old
    old = [6]
    print(new)
    

    如果不上机操作,你觉得会打印什么内容?

      me:[1,2,3,4,5]

    1.请问如何将下边这个列表的'小甲鱼'修改为'小鱿鱼'?

    list1 = [1, [1, 2, ['小甲鱼']], 3, 5, 8, 13, 18]
    

      me:list1[1][2][0]="小鱿鱼"

    2. 要对一个列表进行顺序排序,请问使用什么方法?

      me:sort()

    3.要对一个列表进行逆序排序,请问使用什么方法?

      me : 先sort(),再reverse() 先排序从小到大,在倒置

      参考答案:

    >>> 列表名.sort()
    >>> 列表名.reverse()
    
    或者
    
    >>> 列表名.sort(reverse=True)

    4.列表还有两个内置方法没给大家介绍,不过聪明的你应该可以自己摸索使用的门道吧:copy() 和 clear()

      me:copy(),对列表进行拷贝,clear(),清理列表,将列表中的所有元素删除,留一个空列表。

    5. 你有听说过列表推导式或列表解析吗?
      
    没听过?!没关系,我们现场来学习一下吧,看表达式:

    >>> [ i*i for i in range(10) ]

    你觉得会打印什么内容?

    >>> [i*i for i in range(10)]
    [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

    居然分别打印了0到9各个数的平方,然后还放在列表里边了有木有?!
    列表推导式(List comprehensions)也叫列表解析,灵感取自函数式编程语言 Haskell。Ta 是一个非常有用和灵活的工具,可以用来动态的创建列表,语法如:
    [有关A的表达式 for A in B]
    例如

    >>> list1 = [x**2 for x in range(10)]
    >>> list1
    [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]

    相当于

    list1 = []
    for x in range(10):
        list1.append(x**2)

    问题:请先在 IDLE 中获得下边列表的结果,并按照上方例子把列表推导式还原出来。

    >>> list1 = [(x, y) for x in range(10) for y in range(10) if x%2==0 if y%2!=0]

      me:

    list1=[]
    for x in range(10):
        for y in range(10):
            if x%2==0 and y%2!=0:
                list1.append((x,y))
    print(list1)

      参考答案:

    list1 = []
    for x in range(10):
        for y in range(10):
            if x%2 == 0:
                if y%2 != 0:
                    list1.append((x, y))

    6.活学活用:请使用列表推导式补充被小甲鱼不小心涂掉的部分

       me:没搞出来

      参考答案:

    >>> list3 = [name + '' + slogan[2:] for slogan in list1 for name in list2 if slogan[0] == name[0]]
  • 相关阅读:
    java 数组的基本概念
    java 简单类
    python3 爬虫教学之爬取链家二手房(最下面源码) //以更新源码
    python3 爬虫之爬取安居客二手房资讯(第一版)
    python3 怎么统计英文文档常用词?(附解释)
    python3 怎么爬取新闻网站?
    ASP.NET 线程详解
    EF6 对于实体字段类型转换扩展
    mysql之调优概论
    mysql8之与标准sql的区别
  • 原文地址:https://www.cnblogs.com/kugua7878445/p/11828664.html
Copyright © 2020-2023  润新知