这些常见的python编码习惯,你都会吗
本文分享自华为云社区《不得不知的十个常见PY编码习惯》,作者:码乐。
简介
语言在发展和变化,编码习惯也在发生改变。这里简单聊聊 17个python中常见的编码习惯或者风格。

1,可变数据结构: 注意在函数变量不要使用它
def foo(x=[]):
x.append(1)
print(x) >>>foo()
[1] >>>foo()
[1,1] >>>foo() [1,1,1] def foo(p=None):
if p is None:
p = []
p.append(1)
print(p) foo()
[1]
foo([2,3,4])
[2,3,4,1]
1.1模块的循环导入
我们定义一个老王模块,再定义一个小李模块,相互导入时,将报错
# laowang.py
import xiaoli
count =4
def main():
wilma.pr('Hello')
if __name__ == '__main__':
main() # xiaoli.py
import laowang
def pr(str):
print(str*fired.count)
if __name__== '__main__':
pr("Ok")
导入问题,如果在使用其他语言 比如 shell 脚本引用 python代码时,需要将python项目加入 linux环境变量。 <=python2.7
export PYTON_PATH=$PYTHON_PATH:/xxx/xxx/XXXProject
或者编辑 python虚拟环境,添加 setup.py, 然后执行 python install -e .
1.2 基础规则
该次执行不缓存sys.stdout,直接输出控制台
@参数 -u unbuffered
执行时带参数m,以Script方式执行py模块
@参数 -m
跳过py模块第一行,允许使用非unix形式
@参数 -x
实体具体选项(set implementation-specific option)
@参数 -X
程序读取文件内容并执行
file
程序从stdin 读取
@参数 -
python3 --help # 显示所有参数
dd
2, 内存管理
python 内存回收 基于 引用计数 和 分级回收。
2.1 小的整数 和短小字符,python将缓存以便重复使用
并且is关键字,用于判断两个引用所指对象是否相同
>>> a = 'gd'
>>> b = 'gd'
>>> a is b
True
== 只判断值是否相同
a2 = []
b2 = []
>>> a2 is b2
False
>>> b2 == a2
True
2.2 对象引用时python基本构成方式
赋值的本质 a=1,实际上时修改globals()字典的值,局部变量值的修改locals()的访问和修改
>>> a1
very good man
>>> globals()['a1'] = 'bad good mm'
>>> globals()
2.3 引用对象reference count
sys.getrefcount() 查看对象的引用计数,sys.getrefcount()在查看某个引用时将创建一个临时引用,所以引用计数将多1
>>> c=[1,2,3]
getrefcount #这里c只有一次引用,但是计数时2,因为当前查询有一次临时引用
2
引用计数的减少和增加
>>> d=c
getrefcount # 增加引用d,计数3
3
del d #删除引用d,c的引用计数又重新为2
2.4 垃圾回收机制 garbage collection
垃圾回收时py 独占进行的,大大降低py效率,特定条件下自动启动垃圾回收。
手工回收 gc.collect()
py 运行时分配对象obj allocation 和取消分配对象 deallocation次数被记录,高于垃圾回收阈值,启动垃圾回收
gc.get_threshold()查看该阈值,gc.set)threshold()重新设置该阈值
(700, 10, 10) 700表示启动垃圾回收阈值,10,10表示分别回收的阈值
2.4.1 垃圾回收分代策略 generation,基本假设如下
存活时间越久,越不可能在后面程序中变为垃圾。 这样所有对象分为0,1,2三代,所有新建对象都是0代。某一对象经历垃圾回收,仍然存活,那么它就被归入下一代对象。
垃圾回收时,一定扫描0代对象,如果0代经过一定次数垃圾回收,下一次对0代和1代扫描清理,
当1代也经历一次次数垃圾回收,这启动0,1,2所有对象的扫描
以上gc.get_threshold()返回(700,10,10)两个表示每10次0代垃圾回收,将配置1次1代垃圾回收,每10次1代垃圾回收,才有1次2代垃圾回收。
2.4.2 两个对象相互引用,
相互引用构成引用环 reference cycle,该引用环将给上一节2.4.1的垃圾回收带来困难,
引用环可能构成一些无法使用但引用计数不为0的对象 为了回收该引用环对象,
py复制了每个对象的引用计数为 gc_ref 遍历所有对象,将每个对象引用的对象相应的gc_ref减1,遍历结束后,
gc_ref不为0的对象和这些对象的引用对象,以及继续更新下游引用对象,被爆了,其他对象被回收。
参考 内存管理,函数默认参数,动态类型
2.4.3 迭代
可迭代对象 iter
迭代器 iter + next
生成器 特殊迭代器 yield
def yd():
a = 100
yield a
yield a*8
yield 8000
2.4.4 抽象方法*(函数)
对象方法(self.对象方法),类方法(@classmethod),静态方法(@staticmethod)
抽象方法 需要子类实现的方法 用@abc.abstractmethod以及 metaclass = abc.ABCMeta
使得任何继承自父类的子类必须覆盖实现抽象方法,否则抛出异常
3,其他概念
闭包 closure
闭包指的是 难以读取其他函数内部遍历的函数
实现: 定义在函数内的内部函数可以读取外层函数变量,从而实现闭包
4,惯例
1,判定dict的key是否存在,使用key in dict而不用 has_key
2,not的位置,使用key not in dict 而不用 no key in dict
3, 使用 dict.get(key[,default])如果key存在,返回,否则返回default
4, 数组字典初始化
dic = {}
for k,v in data:
group = dic.setdefault(key,[]) #如果存在,返回dic[key],不存在把dic[key]设为defalut并返回
group.append(v)
from collections import defaultdic
dic = defalutdic(list)
for (k,v) in data:
dic[key].append(v) #所有key都有一个默认值
迭代一个数组,使用for i,e in enumerate(array) 而不是 for i in range(len(array))
enumerate 还有第二个参数
5,py3元组unpack
first, second,*rest, last = range(10)
0 1 2~8 9
6, 函数参数传入
def foo(x,y):
print(x,y)
adict = {'x':1, 'y':2}
foo(**adict) #字典key作为参数名传入参数值
alist=[1,2]
foo(*alist)
7, 字符串连接
name = "Wang" "Hone" # WangHong
8, 解释器中的
上一次接收器的返回值
9,嵌套列表推导式
[(i,j) for i in range(3) for j in range(i)]
10, print重定向
print >>open('a.txt', 'w+'), 'hello,world'
11,反射
#检查是否某个自定的类
isinstance(obj, class)
12,Picking是Python数据结构的序列化过程
存储一个对象,稍后再取出读取
如何pickle 已存在的对象类型到文件
json = {'name':'jack', 'age':100}
json_file = open('json pkl', 'rb')
pickle.dump(json.json_file)
json_file.dump(json,json_file)
json_file.close()
取出
data=pickle.load(json_file)
print(data)
json_file.close()
pickler内建类型和外部方法
类自定义行为
__getinitargs__(self) #
__getnewargs__(self)
Slate 记住它曾经是什么,以及什么时候赋值给它 ?
__slate__
为对象类 提供限制,只能赋予固定的属性名称
13,对象模型Python3和Python2.x之间的主要区别
Python3的string和unicode区别不复存在,因此__unicode__被取消 __bytes__加入进来(与
python2.7的__str__和__unicode__行为类似),用于心的创建字节数组的内建方法
py3默认除法变成了true除法,因此__div__取消
__coerce__被取消,因为与其他魔法方法有功能重复
cmp 取消,与其他魔法方法功能重复
__nonzero__被重命名为
14,断点
6.1, 断点设置后,代码执行到该位置,程序挂起检查程序行为
6.2, 异常断点,到达断点后要执行的操作
6.3, 断点属性,达到断点时要执行的操作
挂起策略,用于定义在遇到断点时是否必须挂起应用程序
对其他断点的依赖,
何时必须击中断点
6.4 消息记录
断点命中消息,命中断点时,控制输出一条日志消息
堆栈跟踪 断点的堆栈跟踪将命中打印到控制台 6.5 断点工具
pdb 交互式代码调试,功能包括
设置断点,单步调试,进入函数调试,查看当前代码,查看栈片段,动态改变变量的值
进入pdb交互界面
命令
break 或b设置断点
continue 或c 继续执行
list或l 查看当前代码段
step或s 进入函数
return或r 执行代码直到当前函数返回
exit或q 中止并退出
next或n 执行下一行
pp 打印变量的值
15, 依赖问题
pycurl 需要contos 7安装python3-devel
具体过程pycurl-centos7
16, py编译 发布流程
1,编译生成pyc文件,建议增加-O优选项
python3 -O -m compileall -b .
2, 删除py文件
find . -name "*.py"|xargs rm -rf
3, 删除__pycache__目录
find . -name "__pycache__" |xargs rm -rf
4, 打包 tar包
cd ..
tar -cjvf xxx.1.1.00.tar.bz2 xxx
5, 或git push到仓库
git push origin master:master
16 常用内置 魔法函数
iter # 在类中实现,可以直接对类进行迭代 类似于如下形式
obj.next 或 next(obj)
call # 在对象直接 进行调用
obj()
、slate 为对象类 提供限制,只能赋予固定的属性名称
__qualname__ # 查看类和当前函数名
>>> D.f.__qualname__
>>> D.f#返回类和函数
通过类字典返回函数,不会 返回函数名
>>> D.__dict__['f']
<function D.f at 0x000001F6C6224670
通过类实例的点运算 查看函数 将直接返回函数
>>> d = D()
>>> d.f
<bound method D.f of <__main__.D object at 0x000001F6C5F42070>>
查看实例的函数对象
>>> d.f.__func__
<function D.f at 0x000001F6C6224670>
>>> d.f.__self__
<__main__.D object at 0x000001F6C5F42070>
17 内置函数 二进制运算
chr
返回整数 i 的字符串格式,如 chr(97) 返回字符 'a' 是 ord的逆运算
chr('8364') (欧元符号)返回 €
ord
返回代表单个Unicode字符的 码点的整数,例如 ord('a')返回整数 97
ord('€') (欧元符号)返回 8364
这些常见的python编码习惯,你都会吗的更多相关文章
- 测试不得不知的python编程小技能-----升级版基础语法和优秀的编码习惯
编程和学习python,最后快速上手.能写小工具,写自动化用例这类要求对鹅厂的测试人员来说都是一些基础的必备素质,但是一个优秀的测试,也是有着一颗开发完美测试工具的心的.但是罗马不是一天构建成,特别是 ...
- Python编码(encode)和解码(Decode)常见的两个错误
项目地址:https://git.io/pytips 0x07 和 0x08 分别介绍了 Python 中的字符串类型(str)和字节类型(byte),以及 Python 编码中最常见也是最顽固的两个 ...
- Python编码——常见的编码设置
1.查看自己电脑的python的编码设置 # -*- coding: utf8 -*- import sys, locale """ locale.getpreferre ...
- Python编码规范(养成好的编码习惯很重要)
学习过程养成良好的编码习惯 1. 类名采用驼峰命名法,即类名的每个首字母都大写,如:class HelloWord,类名不使用下划线 2. 函数名只使用小写字母和下划线 3.定义类后面包含一个文档字符 ...
- 新手常见的python报错及解决方案
此篇文章整理新手编写代码常见的一些错误,有些错误是粗心的错误,但对于新手而已,会折腾很长时间才搞定,所以在此总结下我遇到的一些问题.希望帮助到刚入门的朋友们.后续会不断补充. 目录 1.NameErr ...
- python编码详解--转自(Alex的博客)
原文地址:http://www.cnblogs.com/alex3714/articles/7550940.html 编码回顾 在备编码相关的课件时,在知乎上看到一段关于Python编码的回答 这哥们 ...
- 转--python 编码规范
编程规范 1.1. 命名规范 1.1.1. [强制] 命名不能以下划线或美元符号开始和结尾 反例: name / __name / $Object / name / name$ / Object$ 1 ...
- 系统编码 python编码
编码一直都是一个很让人头疼的问题,尤其是在python里面.花了几天时间,终于把这个问题给弄明白了. 一,什么是编码,编码过程是怎样的?常见的编码方式有哪些? 编码是从一个字符,比如'哈',到一段二进 ...
- Python编码---转自金角大王
本节内容 编码回顾 编码转换 Python的bytes类型 编码回顾 在备编码相关的课件时,在知乎上看到一段关于Python编码的回答 这哥们的这段话说的太对了,搞Python不把编码彻底搞明白,总有 ...
- Python 编码简单说
先说说什么是编码. 编码(encoding)就是把一个字符映射到计算机底层使用的二进制码.编码方案(encoding scheme)规定了字符串是如何编码的. python编码,其实就是对python ...
随机推荐
- Ubuntu更新软件的命令
更新软件源 apt-get update 更新升级所有软件 apt-get upgrade 更新某个软件 apt-get upgrade 名 列出可更新的软件 apt list --upgradabl ...
- 下载、安装CAN-EYE植被参数工具
本文介绍植被指数计算软件CAN-EYE的下载.安装方法. CAN-EYE软件是由法国国家农业研究院(French National Institute of Agricultural Rese ...
- GeoServer发布影像WMTS服务
WMTS提供了一种采用预定义图块方法发布数字地图服务的标准化解决方案. WMTS: 切片地图web服务(OpenGIS Web Map Tile Service) 使用GeoServer发布WMTS服 ...
- 探索CPU的黑盒子:解密指令执行的秘密
引言 在我们之前的章节中,我们着重讲解了CPU内部的处理过程,以及与之密切相关的数据总线知识.在这个基础上,我们今天将继续深入探讨CPU执行指令的相关知识,这对于我们理解计算机的工作原理至关重要. C ...
- 网络基础-OSI七层vsTCP/UDP四层 五层 数据封装
1.0 网络基础 1.1 网络是什么? 网络是信息传输.接收.共享的虚拟平台,通过它把各个点.面.体的信息联系到一起,从而实现这些资源的共享 网络分类:局域网 ,城域网,广域网 1.2 数据通信方式 ...
- InnoDB 存储引擎之 Buffer Pool
Mysql 5.7 InnoDB 存储引擎整体逻辑架构图 一.Buffer Pool 概述 InnoDB 作为一个存储引擎,为了降低磁盘 IO,提升读写性能,必然有相应的缓冲池机制,这个缓冲池就是 B ...
- 字符串小记 I:基本结构与简单匹配(更新中)
0.一些定义 在开始之前,我们先给出一些关于字符串的定义: 记 \(|S|\) 表示字符串 \(S\) 的长度,\(S_i\) 表示该字符串中第 \(i\) 位的字符,\(S_{l,r}\) 表示该字 ...
- git 创建本地分支并关联远程分支
1.查看远程分支 git branch 可以看到,我本地只有dev和master分支.现在同事创建了一个远程分支dev-glq,里面是他的代码.我应该再我本地创建一个分支,并且他的关联远程分支. 2. ...
- openwrt使用tailscale实现内网穿透
问题 之前一直有电信公网ip,最近发现电信公网ip被撤下来了,打电话再去要发现给的是10开头的ip,电信客服还跟我说10开头就是公网ip,= =,根本就不是,无奈使用zerotier进行打洞,把zer ...
- 七个很实用的开源项目「GitHub 热点速览」
本周特推的两个项目都是异常实用的项目,一个接棒上周的视频重制项目 video-retalking 这次则是直接将视频替换成另外一个语种:另外一个则是解决日志阅读问题的 tailspin,让你在成千上万 ...