作者:心叶
时间:2018-04-23 22:18

此处长期维护一些对帮助快速使用python3的一些基础语法,方便日常算法练习使用。

控制语法

break 语句可以跳出 for 和 while 的循环体。如果你从 for 或 while 循环中终止,任何对应的循环 else 块将不执行。

continue语句被用来告诉Python跳过当前循环块中的剩余语句,然后继续进行下一轮循环。

if条件控制

if 表达式:
    语句
    if 表达式:
        语句
    elif 表达式:
        语句
else:
    语句

while循环

Python中没有do..while循环

while 判断条件:
    语句
else:
    语句

for语句

for <variable> in <sequence>:
    <statements>
else:
    <statements>

range()函数

这个函数不得不提,为什么滴?因为在实际用python练习算法题目时,这个函数真的用的太频繁了。

print(list(range(5,9))) #[5, 6, 7, 8]

for i in range(5):print(i,end=' ') #0 1 2 3 4

for i in range(1,3):print(i,end=' ') #1 2

for i in range(0, 10, 3):print(i,end=' ') #0 3 6 9

for i in range(-10, -100, -30):print(i,end=' ') #-10 -40 -70
    

迭代器与生成器

迭代器

迭代器是什么东西?哈哈,有没有想起java中集合的方法iterator()返回迭代器?是的,就是类似这个的存在。

迭代器有两个基本的方法:iter() 和 next(),这点也很类似java(字符串,列表或元组对象都可用iter()方法创建迭代器对象)。

下面先简单演示一下这二个方法的用法:

list=['中国','美国','俄罗斯','埃塞俄比亚']

#1.使用iter()方法获取迭代器对象
it = iter(list) 

#2.使用next()方法依次获取数据
print (next(it)) #打印结果是'中国'
print (next(it)) #打印结果是'美国'

上面的例子应该已经明白这二个方法的用法了,使用iter()方法获取迭代器对象,再用next(it)方法依次获取集合的数据。

当然,到末尾了已经没有可以取的数据的时候,再次调用会抛出异常,因此我们可以借助这个来实现迭代全部的数据,如下:

list=['中国','美国','俄罗斯','埃塞俄比亚']

it = iter(list)  

flag=True; 

while flag:

    try:
        print (next(it))
        
    except StopIteration:
        print ('迭代结束了',end='\n')
        flag=False

除此之外,使用for可以实现类似的效果,如下:

list=['中国','美国','俄罗斯','埃塞俄比亚']

it = iter(list)

for x in it: 
    print (x, end=" ") #'中国','美国','俄罗斯','埃塞俄比亚'

因此,迭代全部的数据肯定不是迭代器存在的全部意义,更多的时候,你可以把它看成一个管理一列数据的对象,需要的时候告诉他一下,他就会给你下一个数据,不像for循环那样一下子迭代结束,你可以在任何需要的时候获取下一个数据。

记住这一个特点,特别是在设计算法或者模式的时候,会很有用的(当然,具体用好他从来都是经验的事情,祝你好运)。

生成器

TS或者ES6+有所了解的人应该都知道yield函数,基本上和这里的差不多用法。

在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回yield的值。并在下一次执行 next()方法时从当前位置继续运行。

上面的说法可能有点不好理解,ok,下面用大白话说一下:

生成器就是一个可以自定义一个生成迭代器对象函数的概念,生成的迭代器对象每次被询问返回下一个数据的时候,自定义的如果返回,使用的就是yield函数,先看下下面的例子:

#定义一下可以生成迭代器对象的函数,类似上面例子中的iter()方法
def generatorDemo(array):
    index=0
    while(index<len(array)):
        #你每次调用next(it)的时候,就是这里返回给你的数据
        yield array[index]
        index=index+1

#用上面的迭代器对象生成函数生成一个迭代器对象
it=generatorDemo(['中国','美国','俄罗斯','埃塞俄比亚'])
 
#下面就是和之前一样使用
flag=True
while flag:
    try:
        print (next(it), end=" ")
    except StopIteration:
        flag=False

#执行结果:中国 美国 俄罗斯 埃塞俄比亚 
        

因此,你可以从二个角度来理解生成器:

1.一个和迭代器配合使用的迭代器对象生成方法;

2.更本质的理解:yield类似return,可以返回数据,不过不同的是,可以多次返回数据,调用一下返回一下,再次调用返回下一个yield定义返回数据的地方,就如同上面的例子,直到yield语句全部完毕再次调用会抛出错误。

如果你问我什么时候使用他,这具体看业务需求,就好比if语句一样,他就在那里,需要用的时候可以记起来他,就够了。

函数

具体就不用多说明了,直接给出定义,然后说几个重要的问题。

def 函数名(参数列表):
    函数体

参数传递

在 python 中,strings, tuples, 和 numbers 是不可更改的对象,而 list,dict 等则是可以修改的对象。

函数中传递参数的时候,不可更改的对象和可以修改的对象在操作影响上是有很大区别的,用一句话说明的话就是:不可更改的对象类似传递的是值,可以修改的对象传递的是'指针',也就是引用传递,应该可以感受出来区别了吧。

python 中一切都是对象,严格意义我们不能说值传递还是引用传递,我们应该说传不可变对象和传可变对象。

参数

参数有四点,具体的很多和ES很像,不过在第一点上和ES区别很大,下面来简单说明一下:

1.必需参数:就是你定义函数的时候,定义了几个参数,调用的时候就要传递几个,当然是普通定义方法,不包括下面的不定长参数,这点ES就很随意了;

2.关键字参数:举个例子,比如你定义了一个函数有二个参数age和name,函数名称是getInfo,正常调用是依次传递参数:getInfo(7,'yelloxing'),当然你可以不这样,你还可以这样:

getInfo(name='yelloxing',age=7);

3.默认参数:这个就和ES6差不多意思,举例,定义函数时(没有写全,值写函数头部):

getInfo(age,name='默认名称');

4.不定长参数:定义方法:getInfo(age,name,*vartuple),这样多传递的数据就全部在vartuple中,调用前它是一个空元组。

别的更多细节说明就到此为止,如果后续有必要再添加或单独整理,此时的已经够用了。


心叶
304 声望114 粉丝

我还惊讶地意识到, 在我生命中有很多时刻, 每当我遇到一个遥不可及、令人害怕的情境,并感到惊慌失措时, 我都能够应付——因为我回想起了很久以前自己上过的那一课。