Python知识点进阶——细节问题

int()强制转换浮点数

在int()的强制转换浮点数时候,不管是正数还是负数,只取整数部分。


注意:这里不是向上或者向下取整,也不是四舍五入。


无限递归

递归是为了将问题简化为更小规模的同类型问题,最后加以解决。

但是有一种情况是递归时不断调用自身,达到不了最简单的情况,所以一直找不到递归的出口


当我们运行调用这个函数时,系统抛出异常,意思是达到了最大的递归深度。


字符串是不可变的

字符串和元组是不可变的数据类型,那字符串的不可变性体现在哪儿呢?


结果抛出异常,提示不让我修改,体现了字符串的不可变性,如果执意修改,可以这样:


联合使用字符串的切片和拼接可完成。


一些遗漏的字符串方法

upper()和lower()方法

upper():能将一个字符串的字母全变成大写,lower()与之相反。



find():可以在字符串中查找子串是否存在。


      如果找到,返回的是子串的起始索引位置,例如Hello是从字符串索引0位置开始,空格是在索引5位置,当找不到子串时,返回-1,而不是抛出异常。

还可以限定查找开始的索引位置:


      空格的索引是5,当我们从索引3开始往后找,能找到空格;当我们从索引7开始找,则返回没找到,因为索引7已经在索引5之后了。


字符串快速转换为列表的方法



split方法中默认是空格,所以有以上两种写法。


字典中按照键的顺序输出

字典有三大特性其中有一个就是无序性。


如果想要按照key的字母顺序打印,则可



通过value找到key


自定义一个reverse——lookup的函数,传入两个参数,第一个是要查询的字典,第二个是要查的值。

然后循环字典,将键对应的值分别和要查找的值比较,当出现一样的时候就返回。

当如果查找不到时,应该返回找不到,可以使用raise关键字:它可以抛出异常。


当找到对应的key,直接运行return,当没有找到时,最后会抛出设定的Lookup


可变长元组参数

*开头的收集到的是元组参数,既然有收集,可会有分散,例子


divmod函数是一个求商和余数的函数,这里返回了4和1。

如果我们一步到位,发现系统抛出了异常,需要两个参数,只给了一个。

此时需要尝试分散,也就是今天介绍的内从。


我们在传入的元组前加了一个 * 号,即可将元祖拆开,此时返回正常了。


序列合体

将序列(字符串,列表,元组)相互合并的操作

zip()函数接收两个或者多个序列,返回一个元组列表,每个元组包含来自每个序列中的一个元素


返回的结果是一个zip对象,可以简单的认为是一个压缩包。

当我们要获取查看它的元素,可以使用循环变量,如果想将结果放在一个list中,可以这样:


当然还可以将字符串和列表合并:


甚至多个序列合并:


zip()函数的出现为我们创建字典提供了新方法:



文件名和路径

返回当前目录:


返回当前目录的好处:

1.方便构造文件操作路径

2.提醒我们当前在什么路径


检查该目录下是否存在某个文件:












posted @ 2018-04-25 20:42  Mayny#  阅读(155)  评论(0编辑  收藏  举报