Python进阶系列连载(1)——那些容易被忽略的问题(上)

本篇我们来聊一聊一些在入门部分容易被忽略的问题

int()强制转换浮点数

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

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

无限递归

还记得我们讲的俄罗斯套娃么,还记得数列求通项公式么,都用到了递归的思想

如果不记得了,记得回看入门教程哦~

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

但是有一种情况是递归时不断调用自身,达到不了最简单的情况(例如俄罗斯套娃一层层打开到最内层的)

所以一直找不到递归的出口

我们定义了一个函数名为recurse

然后函数体中调用自身

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

你可以认为系统设置了一个最大递归次数,如果超过这个次数还没解决问题,则抛出异常

简答点说,就是:绕来绕去你怎么还没解决问题,你是要上天么!

这种问题,我们要避免

字符串是不可变的

在入门阶段我们说过,字符串和元组是不可变的数据类型,那字符串的不可变体现在哪呢?

看个例子:

如果我想改名字,而且改的是姓【不要当真,只是为了举例子,我爸应该看不到这篇文章的】

我把姓 '王' 改为 ' 方',我就做了如下修改: 

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

可以这样

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

一些遗漏的字符串方法

upper()和lower()方法

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

find()方法

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

如果找到,返回的是子串的起始索引位置,例如Hello是从字符串索引0位置开始,空格是在索引5位置

当找不到子串时,返回-1,而不是抛出异常

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

我们知道,空格的索引是5,当我们从索引3开始往后找,能找到空格

当我们从索引7开始找,则返回没找到,因为索引7已经在索引5之后了

注意操作的返回值

我们用a来 接盘 , 啊呸!接收来自print的返回值,发现a是NoneType,所以print是没有返回值的

例如在列表中,你希望接收排序的结果,你可能会这样写:

发现这样是没有结果的!

你还能找出哪些容易犯错的地方呢?

人生苦短,我选Python!

猜你喜欢

转载自blog.csdn.net/qq_40925239/article/details/82793597