python的30个冷知识

目录

基本常识

数据结构部分

输入输出函数部分

基本常识

Python 没有 switch / case 语句。

如何中断多层循环?这里有窍门,那就是循环体自带else分支,不只是if有,while和for都有else分支。循环体的else分支触发条件是循环正常结束。如果循环内被break跳出,就不执行else。所以这个逻辑是:如果循环内break了,不触发else,则执行下一句外层循环中的break;如果正常结束,执行else分支里的continue,直接跳转到外层循环的下一轮,跳过了第二个break。

为了节省内存,python中有个叫整数池的东西,据我在python3.5.4上测试,整数池包括-5~256。也就是说,在[-5, 256]范围内,值相同的变量都指向了同一内存地址。

__file__代表的是文件的路径,os.path.dirname(path)表示的是提取不包括路径的字符串,但是有一点是os.path.dirname(file)所在脚本是以绝对路径运行的,则会输出该脚本所在的绝对路径,若以相对路径运行,则输出空目录。

python2.7的int的32位的范围为-231~231-1 64位为-263~263-1,在3.5中int长度理论上是无限的

python的函数参数的传递,简单类型都是按照值传递的,并且没办法用引用传递,当参数有多于一个元素的时候,按照引用传递

注意数学运算符 **和 ^ 和//,尤其注意python的除法,双线//始终实现整除操作,永远是向下取整,而且如果小于这个被余数,可能直接给整没了,还得事先判断一下,这点相当值得注意,但/可能是取小数,在python3中,不管是不是整数,都会取小数,但在python2中就不是这样,python2与c语言看齐,%仍然为取模,在python中,**是幂次计算,而^代表位操作。

不使用临时变量交换变量的方法:x, y  = y,x,直接更换就行,真的很方便

切记,在使用范围的时候(就是一个区间),前面一项是开始项,后面一项是长度,如果要表示结尾项的话,需要这样[0:(结尾位置)+1],或者你要改变这个坏习惯,一般遍历的话,直接它的长度就ok,说明白一点,是左闭右开类型,包括左边,但不包括右边

逆序输出用:for i in reversed(l):

python没有三目元表达式,但是可以这么写:h = "变量1"if a>b else "变量2" 充当三目元表达式。

短暂的循环甚至可以这么写:list[word] for word in poem  ,当作表达式来用,完全可以,甚至可以双重循环:([list[word] for word in poem]) for poem in poems

数据结构部分

counter类是非常好用的一种用于计数的类,把其他的实例赋给它,然后它就能把元素出现的个数以字典的形式储存好,用update来追加,减少使用subs tract,相当实用。

string转int类型:i = int(s), int转string类型:s = str(i),另外,这些不止一个参数,第二个参数是转换成多少进制。

list超有用合集:1.用append()添加元素,用 del 删除元素(没有括号),两个list相+代表组合,一个list*一个数代表重复,x in list代表元素存在性查询,max返回列表元素最大值,min为返回最小值,cmp()为比较,如果一方为数字,则这个比较大,否则,按字母顺序进行比较,如果所有元素都相等,则返回0,-1代表小于号,1代表大于号,Python 3.X 的版本中已经没有 cmp 函数,如果你需要实现比较功能,需要引入 operator 模块,适合任何对象,list.count(seq)代表统计某个元素出现的次数,extend,大量追加多个值,pop(),返回并移除一个值,默认为最后一个值,因此不仅仅可以作为栈用,remove()移除某个值的第一个匹配项,reverse()反向列表中的元素,sort,对原列表进行排序,默认升序

字典directory实际上是一个哈希表,添加一个键值对直接用中括号写就好了,删除一个键值对用del,清除一个字典用.clear(),删除字典用del,str(dict)表示输出字典的可打印的字符串表示,type(var)返回输入变量类型,dict.has_key(key)检查是否有这个键,dict.values(),以list的方式返回所有值,dict.key()以list的方式返回所有键,能打印,但几乎什么也不支持,pop(key)返回这个值并删除

list去重 l = list(set(l)),set是一种不允许有重复的类型

输入输出

python将两个互相排列的数组分别放置

x = "a 1 b 2 c 3 d 4 e 5"

y = x.split()

y1 = y[0::2]

y2 = y[1::2]

print(y1)

print(y2)

123456

倒序输出的有趣方法:x[::-1],或者eversed(x),或者x.reverse(),但字符串不能用这个,因为字符串是固定的。

有一个zip函数可以将两个list转换成一个dict,相当于又组合起来,这个不错

dict = dict(zip(list1, list2)) 会按照最小的长度

另外,如果要将一串字符串转换成单个字母并存入list中,直接用l=list(str)即可

python3 里 input() 默认接收到的是 str 类型。在 Python3.x 中 raw_input( ) 和 input( ) 进行了整合,去除了 raw_input( ),仅保留了 input( ) 函数,其接收任意任性输入,将所有输入默认为字符串处理,并返回字符串类型。input接受带空格的字符串,作分割时用map映射就很舒服,但一般也不会这么着出题

a,b=list(map(int,input().split()))#map() 会根据提供的函数对指定序列做映射。split()没有参数默认分割空格,tab或者回车符,第一个参数是一个函数,作用是对每个参数进行一次visit,看来是转成int类型的了

str.format函数,通过位置,通过关键字,进行格式化的一个函数

填充与对齐:var:char>int,保留两位小数:.2f,金额分隔符::,,几种进制b d o x

关于一句话输出空格分隔的东西,除非里面是字符串,才能这么干

print(" ".join(str(i) for i in s))

否则不行,必须转换成字符串,这么干

num_list_new = [str(x) for x in num_list]

格式化的%与format用法其实是一样的,只不过用.代替%而已

函数部分

lambda表达式会返回一个函数对象,如果没有变量接受这个返回值的话,它很快就会被丢弃。也正是由于lambda只是一个表达式,所以它可以直接作为list和dict的成员。sorted(wordFreq.items(), key = lambda x: -x[1])

zip函数一般是将两个参数压缩成一个zip对象,元素个数与最短的列表一致,zip(*ziped)意思是解压,其实zip的特性多用于dict

python的库是超级多的,很多轮子都不用重复制造

排列组合:首先import itertools , 然后使用 list(itertools.permutations([1,2,3,4],2))#第二个参数表示要选择几个对象

而combinations则是不用考虑顺序的排列组合,参数都一样

lstrip(), rstrip(), strip()来去除字符串前后空格,默认参数为空格,实际上还可以删除很多,用“”括起来的参数就行,用“[xxx]”括起来代表切除首尾是这些字母,直到遇见不是这个字母为止

re.sub(pattern, repl, string, count)代表替换字符串中的某个字符,但要import re,第四个参数指替换个数。默认为0,表示每个匹配项都替换。

其中patten是正则表达式最好,返回string,python中string不是可以改变的

用split(’ ')来分割字符串,这个是字符串自带的,但如果有多个空格组合在一起的话,则会有空元素产生,这时必须借助re.split(),但需要用到正则表达式了

超强悍的map函数,运用function将一个变量进行处理,然后映射返回出来,适用于处理字符串,分割字符串等

你可能感兴趣的:(python的30个冷知识)