zoukankan      html  css  js  c++  java
  • python补充知识点

    1、 在python2中用xrange,在python3中直接使用range就好了

    2、 常数

    None在逻辑判断的时候指代False,其他方式不代表True或者False

    3、 for循环只作用域容器

    4、range函数,range只能遍历数字,如果遍历下标可以和len函数结合

    for i in range(len(list/tuple/set))
    >>> range(1,5)  代表从1到5(不包含5)
    [1, 2, 3, 4]
    
    range(start,end,step)  
    负数step,也就是-z的时候  range[x,y,z]==>[x,x+z.....,最后的值等于y-z] 
    >>> print ([i for i in range(3,-1,-1)])
    [3, 2, 1, 0]
    >>> for i in range(5,-1,-1):print(i)
    ...
    5
    4
    3
    2
    1
    0
    #正数step,也就是+z的时候,range(x,y,z)===>[x,x+z,...最后的值为y-z]
    
    python2中
    >>> range(1,5,2) 代表从1到5(不包含5) 中间隔2个
    [1, 3]
    >>> range(5)
    [0, 1, 2, 3, 4]
    >>> xrange(1,5)
    xrange(1, 5)
    >>> xrange(5)
    xrange(5)
    python3中
    >>> print([i for i in range(1,5)])  代表从1到5(不包含5)
    [1, 2, 3, 4]
    >>> print([i for i in range(5)]) 代表从0到5(不包含5)
    [0, 1, 2, 3, 4]
    >>> print([i for i in range(1,5,2)])
    [1, 3]
    

    5、python函数也是一个值,可以当成一个参数传递

    >>> def g(x):
    ...   return x+100
    ...
    >>> def f(g,x):
    ...   return g(x)+100
    ...
    >>> print(f(g,100))
    300
    也可以写lambda表达式
    >>> print(f(lambda x:x*100,100))
    10100
    

    6、lambda帮助排序

    li=[[5,2],[1,2],[2,3]]
    >>> li.sort(key=lambda x: x[0]) 传入参数作为排序的KEY
    >>> print(li)
    [[1, 2], [2, 3], [5, 2]]
    

    7、切片

    li[start:end:step] 
    start为正,end为正
    step为正数的时候
    >>> li
    [1, 2, 3, 4, 5]
    >>> li[0:4:2]
    [1, 3]
    >>> li[0:4:3]
    [1, 4]
    start为正,end为负数
    >>> a[1:-2]
    [2, 3, 4, 5]
    >>> a[1:]
    [2, 3, 4, 5, 6, 7]
    
    start为负数,从后边开始取值,这里注意,start所对应的值的下标,
    一定要小于或者等于end对应的值的下标,否则会没有值。也就是说切片是从左往右的,
    不可逆转,除非反转 [1, 2, 3, 4, 5, 6, 7] >>> a[-6:2] start对应的值的下标等于end对应值的下标 [2] >>> a[-6] 2 >>> a[-6:1] start对应的值的下标大于end对应值的下标 [] >>> a[-6:5] [2, 3, 4, 5] >>> a [1, 2, 3, 4, 5, 6, 7] >>> a[-1] 7 start为正,end为负 end为负是取最大值下标加上这个负数的值为下标的值 >>> a[:-1] [1, 2, 3, 4, 5, 6] >>> a[:] [1, 2, 3, 4, 5, 6, 7] >>> a[1:-1] [2, 3, 4, 5, 6] >>> a[1:-2] [2, 3, 4, 5] >>> a[1:-5] [2] start为负,end为负数 >>> a[-1:] [7] >>> a[-1:-1] [] >>> a[-2:-1] [6] step为负数 反转,中间的数字值加上负数个 >>> a[::-1] 反转 [7, 6, 5, 4, 3, 2, 1] >>> a[::-2] 反转,中间的数字差2 [7, 5, 3, 1] >>> a[::-3] 反转并且中间的数字差3 [7, 4, 1] >>> a[5:3:-1] 反转,开始的位置为下标为5到下标为3 [6, 5] >>> a[5:2:-2] 反转 开始的位置下标为5,到下标为2,中间差2 [6, 4] >>> a[5:2:-1] [6, 5, 4] 切片核心思想方法:只要注意是否是反转的,然后大脑中要有构思,注意好start和end对应的值的下标位置,
    只要start对应的值的下标位置小于或者等于end下标对应值的位置都能获取到值,如果获取到的是空列表,
    要么这个列表就是空列表,要么就是start对应的值的下标大于end对应的值的下标

    鸭子类型:

    class R1:
    	def run(self):
    		print(“R1:run”)
    class R2:
    	def run(self):
    		print(“R2:run”)
    上面这两个类都可以由run方法来执行
    run(R1())
    run(R2())
    在python里面,不是特别注重继承,只关注接口,只要看着像鸭子,走起路来像鸭子,那么就是鸭子,这就是鸭子类型
    

    文本读写:  主要用下面第三种方法

    慎用readlines,会把全部文件加载到列表中
    read 的时候也要注意
    readline 只读取一行
    如果遇到上G的文件的时候有两种方式
    1、	用readline一行一行的读取
    2、	read(n).。指定大小
    1 KB = 1024 Bytes
    1 MB = 1024 KB
    1 GB = 1024 MB
    3、下面是一种以xreadline的方式读取文件
    with open("a.txt") as f:
        for i in f:
            dosomething(i)
    
    多线程:
    import threading
    
    
    def thread_func(x):
        print("%d
    " %(x*100))
    
    threads=[]
    for i in range(5):
        threads.append(threading.Thread(target=thread_func,args=(100,)))
    
    for thread in threads:
        thread.start()
    
    for thread in threads:
        thread.join()
    创建多线程主要注意下面:
    1、	指定线程执行函数
    2、	args参数指定的是元祖,所以这里要加上逗号,否则会出错
    3、执行上面的五个任务并不是由一个线程完成的,因为有全局解释器锁的缘故,所以同一时间只能有一个线程来执行,但是一个线程执行完毕之后,全局锁就会释放
    

    错误异常处理

    1、当程序中没有处理这个异常的上下文,就用来抛出异常

    2、处理异常防止资源泄漏

    try:
    	r=10/0
    except ZeroDivisionError as e:
    	print(type(e))
    	print(e)
    finally:
    	#这里用来防止资源泄漏   (防止服务器端的异常泄漏)
    	print(“Always come here”)
    
  • 相关阅读:
    如何查看一个表的块使用状况
    esp8266烧录Html文件,实现内置网页控制设备!
    python一键电影搜索与下载
    基于 Vue BootStrap的迷你Chrome插件
    SpringBoot之自定义验证码
    iOS 图片部分模糊,类似于美图秀秀
    python实现的电影票房数据可视化
    坦克大战-C语言-详注版
    微信小程序-自定义底部导航
    微信小程序--搜索关键词高亮
  • 原文地址:https://www.cnblogs.com/pyrene/p/7491815.html
Copyright © 2011-2022 走看看