本篇我们来聊一聊一些在入门部分容易被忽略的问题
int()强制转换浮点数
在int()的强制转换浮点数时候,不管是正数还是负数,只取整数部分。
注意:这里不是向上或者向下取整,也不是四舍五入。
无限递归
还记得我们讲的俄罗斯套娃么,还记得数列求通项公式么,都用到了递归的思想
如果不记得了,记得回看入门教程哦~
递归是为了将问题简化为更小规模的同类型问题,最后加以解决。
但是有一种情况是递归时不断调用自身,达到不了最简单的情况(例如俄罗斯套娃一层层打开到最内层的)
所以一直找不到递归的出口
我们定义了一个函数名为recurse
然后函数体中调用自身
当我们运行调用这个函数时,系统抛出异常,意思是达到了最大的递归深度。
你可以认为系统设置了一个最大递归次数,如果超过这个次数还没解决问题,则抛出异常
简答点说,就是:绕来绕去你怎么还没解决问题,你是要上天么!
这种问题,我们要避免!
字符串是不可变的
在入门阶段我们说过,字符串和元组是不可变的数据类型,那字符串的不可变体现在哪呢?
看个例子:
如果我想改名字,而且改的是姓【不要当真,只是为了举例子,我爸应该看不到这篇文章的】
我把姓 '王' 改为 ' 方',我就做了如下修改:
结果抛出异常,提示不让我修改,这体现了字符串的不可变性,如果你执意要改呢?
可以这样
联合使用字符串的切片和拼接完成~
一些遗漏的字符串方法
upper()和lower()方法
upper()能将一个字符串的字母全变成大写,lower()与之相反:
find()方法
find()可以在字符串中查找子串是否存在:
如果找到,返回的是子串的起始索引位置,例如Hello是从字符串索引0位置开始,空格是在索引5位置
当找不到子串时,返回-1,而不是抛出异常
还可以限定查找开始的索引位置:
我们知道,空格的索引是5,当我们从索引3开始往后找,能找到空格
当我们从索引7开始找,则返回没找到,因为索引7已经在索引5之后了
注意操作的返回值
我们用a来 接盘 , 啊呸!接收来自print的返回值,发现a是NoneType,所以print是没有返回值的
例如在列表中,你希望接收排序的结果,你可能会这样写:
发现这样是没有结果的!
你还能找出哪些容易犯错的地方呢?
人生苦短,我选Python!