python 高级编程读书笔记(一)
python 高级编程读书笔记,记录一下基础和高级用法
使用 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
pip freeze
会发现输出的所有的 python 包,包括 python 标准库的,所以独立的 python 运行环境很重要,使用 virtualenv 或者 pipenv 建立独立的 python 环境很重要。 之后复制所有使用的模块到 requirements.txt 文件里。
这个文件含有当前项目使用的 python 包为了避免一个一个安装项目中缺失的包我们一般用。
pip install -r requirements.txt
即可安装当前项目使用的包。
import pdb
pdb.set_trance()
命令 n:执行下一步,其他的命令可以通过
help pdb
进行获取。
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 循环自然结束的而不是因为 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 的连接已经建立就不重新创建了。单例模式的一种。实例之间共享属性达到节省资源的目的。
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 学习开发。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.