python高级编程读书笔记(一)

python高级编程读书笔记(一)

python 高级编程读书笔记,记录一下基础和高级用法

python2和python3兼容处理

使用sys模块使程序python2和python3兼容

import sys

ver=sys.version_info
#(major=3, minor=6, micro=6)

if ver<(3,0,0):# 3是版本号,0是此版本号,第二个0修订号。
    import urllib2
else:
   import urllib 

获取当前环境所用的python包

pip freeze

会发现输出的所有的python包,包括python标准库的,所以独立的python运行环境很重要,使用virtualenv或者pipenv建立独立的python环境很重要。
之后复制所有使用的模块到requirements.txt文件里。

requirements.txt 的用法

这个文件含有当前项目使用的python包为了避免一个一个安装项目中缺失的包我们一般用。

pip install -r requirements.txt

即可安装当前项目使用的包。

使用pdb模块交互式调试

import pdb
pdb.set_trance()

命令 n:执行下一步,其他的命令可以通过

help pdb 

进行获取。

zip均匀分配迭代对象

for i in zip(["name","sex","age"],["张三","男",25]):
    print(i)

输出

('name''张三')
('sex''男')
('age', 25)

两个列表转化为字典的形式

print(dict(zip(["name","sex","age"],["张三","男",25])))

输出

{'name''张三''sex''男''age': 25}

序列解包

a,b,c=("this","is","seq")
a1,*b1,c1=("this","is","seq",'tuple')
a2,b2,*c2=("this","is","seq",'tuple')
print(a)
print(b1)
print(c2)

输出

this
['is''seq']
['seq''tuple']

字典推导式

d={f"num{num}":num**2 for num in range(10)}
print(d)

输出

{'num0': 0, 'num1': 1, 'num2': 4, 'num3': 9, 'num4': 16, 'num5': 25, 'num6': 36, 'num7': 49, 'num8': 64, 'num9': 81}

for….else语句

在for后面加else的语句,表示是for循环自然结束的而不是因为break结束的。

for  i in range(10):
    if i==6:
        break

else:
    print("跳出循环")


for  i in range(10):
    if i==6:
        pass

else:
    print("自然循环结束"

输出

自然循环结束

函数注解

def foo(num:4>5 and 6>7)->(6666):
    return num+1
print(foo(5))

参数的冒号后计算注解值的表达式,->填入返回值类型
以上这种注解只会让人糊涂没什么卵用。

描述符

class RevealAcess(object):
    def __init__(self, initval=None, name='var'):
        self.val = initval
        self.name = name

    def __get__(self, obj, objtype):
        print("Retrieving"self.name)
        return self.val

    def __set__(self, obj, val):
        print("updating"self.name)
        self.val = val


class MyClass(object):
    x = RevealAcess(10'var "x"')
    y = 5


if __name__ == "__main__":
    m = MyClass()
    print(m.x)
    m.x = 20
    m.x
    print(m.y)

输出

Retrieving var "x"
10
updating var "x"
Retrieving var "x"
5

如果一个类的某个属性有数据描述符(含有__get__,
__set__方法的类称之为数据描述符),
通过上述的例子可以知道,每次读取属性的时候会调用 __get__方法
每次对属性赋值的时候调用__set__方法,只实现了__get__的称之为非数据描述符。

延迟求值属性

import pymongo
class A():
    def __init__(self):
        self._client = None

    def __get__(self, instance, owner):
        if self._client is None:
            print("创建mongodb连接")
            self._client = pymongo.MongoClient(host='127.0.0.1',port=27017,maxPoolSize=10)
        else:
            print('使用存在连接!')
        return self._client
class B():
    db=A()

if __name__ == '__main__':
    m=B()
    print(m.db)
    print(m.db)

如果mongodb的连接已经建立就不重新创建了。单例模式的一种。实例之间共享属性达到节省资源的目的。

property的使用

from requests_html import HTMLSession


class Spider():
    __slots__ = ['url''new_url''session']  # 冻结属性

    def __init__(self):
        self.url = "https://www.baidu.com"
        self.new_url = None
        self.session = HTMLSession()

    @property
    def get_url(self):
        return self.url

    @get_url.setter
    def get_url(self, key):
        self.url = f'{self.url}/s?wd={key}'

    def get_html(self):
        req = self.session.get(self.url)
        if req.status_code == 200:
            return req.text


if __name__ == '__main__':
    s = Spider()
    s.get_url = 'python'
    print(s.get_html())

使用property装饰器修饰函数get_url,在调用的时候就可以当属性直接调用,
然后在此基础上定义同名函数,使用同名函数装饰器的setter方法修饰函数,可以实现赋值的功能。

更多工具使用以及python技巧,请关注公众号:python学习开发。

如果您喜欢我的文章不防动动小手转发一波,谢谢。
点击阅读原文进入我的博客园,看代码更方便。由于人数超过100所以需要添加我微信:italocxa,然后拉您入群。