网络自动化运维教程
上QQ阅读APP看书,第一时间看更新

1.3 知识准备

1.3.1 Python基础

Python是一种解释型、面向对象的高级程序设计语言,功能强大,具有很多区别于其他语言的个性化特点。在Python中,一切皆是对象。

1.Python简介

Python语法简单,易于阅读和理解,便于快速地构建项目并快速地进行改进。Python用途广泛,对初学者友好,在入门级编程人员中很受欢迎。Python是开源的,有丰富的、不断增长的第三方模块来扩展其功能。Python还拥有一个庞大而活跃的社区,在Python的模块和库方面做出了贡献,并为其他应用者提供了有用的资源。

目前(截至2022年9月)Python的最新版本为3.10.7。在开始学习使用Python之前,选择一个合适的集成开发环境(Integrated Development Environment,IDE),有利于我们快速上手Python,在学习中起到事半功倍的效果。Python的集成开发环境有很多,这里列出本书用到的集成开发环境。

(1)IDLE。IDLE是Python自带的、默认的、入门级集成开发环境,包含交互式和文件式两种模式。在交互式环境下可以编写一行或者多行语句并且立刻看到结果。在文件式环境下可以像其他文本工具类一样编写语句。通常我们只用它进行教学以及展示、测试和调试代码,不建议使用它进行实际的开发工作。

(2)PyCharm。PyCharm是唯一一款专门面向Python的全功能集成开发环境。PyCharm在所有的集成类工具中相对简单且集成度较高,使用人数最多,适合编写较大、较复杂的程序。其代码自动补全功能在同类产品中几乎是最优秀的。

(3)Jupyter Notebook。Jupyter Notebook是一个开源的Web应用程序,非常方便开发者创建和共享代码文档。对于Python学习者而言,Jupyter Notebook提供了一个非常友好的环境,允许把代码写入独立的单元中,可单独执行,无须从头开始执行。

2.基础语法

基础语法是编程语言最基础的部分,不同的编程语言,如C语言、C++、Java、Python等,它们在基础语法的细节上都不尽相同,需要区别对待。

(1)标识符

标识符就是变量、常量、函数、类等对象使用的名称。需要注意的是,Python中的标识符是严格区分字母大小写的。标识符的第一个字符必须是字母表中的字母或下画线“_”,其他部分由字母、数字和下画线组成。标识符不能与Python的关键字和内置函数的名称相同。

(2)关键字

关键字也称为保留字,是Python官方确定的语法功能的专用标识符,不能用作任何自定义标识符。关键字只包含小写字母。Python的标准库提供了一个keyword模块,可以输出当前版本的所有关键字。

(3)注释

程序中不仅有代码,还有很多注释。注释有说明性质的,也有帮助性质的。它们在代码执行过程中相当于不存在,但在代码维护、解释、测试等方面发挥着不可或缺的重要作用。

在Python中,以符号“#”为单行注释的开始,从它往后到本行末尾的内容都是注释内容。如果想注释多行语句,则只能在每行的开头加上符号“#”。

很多时候,在一些Python脚本文件的开头都能看到以“#”开头的两行代码,它们不是注释,而是一些设定。这两行代码的特点是位置在文件的顶行、顶左,没有空格和空行。

第一行用于指定运行脚本的Python解释器,为Linux专用,Windows中不需要使用。第二行用于指定代码的编码方式。Python 3全面支持Unicode编码,默认采用UTF-8编码,这里可以不需要。但在Python 2中,通常都需要这一行。

(4)语句缩进

Python最具特色的语法格式就是使用缩进来表示代码块,不像其他编程语言使用花括号或其他符号。相同层次的语句具有相同的缩进。

Python缩进规则是指在定义类、函数、流程控制语句、异常处理语句等时,行尾的冒号和下一行的缩进表示下一个代码块的开始,而缩进的结束表示代码块的结束。

Python官方的代码规范PEP 8建议使用4个空格作为缩进。在PyCharm中,如果缩进的空格数不一致,则会抛出名为“IndentationError”的异常。

(5)多行语句

Python中,通常一行就是一条语句,一条语句通常也不会超过一行。但Python并没有从语法层面完全禁止在一行中使用多条语句,可以使用分号使多条语句在一行,举例如下。

上面这一行包含3条语句,用分号分隔。但是强烈建议不要这么做,因为这样会导致代码阅读困难、维护耗时,且容易出错。

但当一条语句实在太长时,也是可以占用多行的,可以使用反斜线来实现多行语句。例如,以下字符串

可以通过使用反斜线来实现一条语句的多行表示:

方括号、花括号或圆括号中的多行语句不需要使用反斜线,直接按Enter键换行即可。下面的函数参数过多,将所有参数放在一行会导致阅读困难,可以使用多行表示以便阅读。

PEP 8建议每一行的字符不超过79个。

3.数据类型

Python是一门弱类型语言,变量使用前无须声明,变量名可以看作对象的引用。

Python中有许多内置的基本数据类型,分为数字(number)、字符串(string)、列表(list)、元组(tuple)、字典(dict)、集合(set)以及一些不太常用的数据类型,如字节串(byte)等。这些数据类型可以分成以下几种类型。

(1)可变类型:列表、字典和集合。

(2)不可变类型:数字、字符串和元组。

(3)序列类型:字符串、列表、元组和字典。

(4)非序列类型:集合。

4.流程控制

流程控制指的是代码运行逻辑、分支走向、循环控制,是体现程序执行顺序的操作。流程控制结构一般分为顺序结构、选择结构和循环结构。

(1)顺序结构是指程序逐行执行,所有语句都按照它们在文件中写入的顺序执行。

(2)选择结构也称分支结构,是指程序有选择地执行代码,可以跳过没用的代码,只执行有用的代码。通常有如下两种选择结构。

●条件判断:if/elif/else。

●异常处理:try/except。

(3)循环结构是指程序不断地重复执行同一段代码。通常有如下两种循环结构。

●for循环。

●while循环。

5.定义函数

编写代码时,很多地方可能需要实现同样的功能,造成同样的一段代码重复出现。重复出现的代码可能只是一个包含3~5行的代码块,也可能是一个包含更多行的代码序列。当代码需要更新时,必须更新所有重复出现的代码,且容易出错。

此时,可以创建一个函数,包含一段重复出现的代码。每次需要重复使用这段代码时,只需调用函数即可。函数不仅允许命名代码块,还允许通过参数为函数传递不同的数据,并根据参数获得不同的结果。

函数是具有名称、可以根据需要多次调用的代码块。函数允许我们将常用的代码以固定的格式封装成一个独立的模块,只要知道这个模块的名称就可以重复使用它。

(1)函数定义

定义函数使用关键字def,def后跟函数名和圆括号,在圆括号内定义函数接收的参数,也可以不定义参数。圆括号后是冒号,函数体(函数的代码块)以冒号开始,并且统一缩进。使用return语句结束函数,默认返回None。return语句依然在函数体内部,不能回退缩进。直到函数的所有代码写完,才回退缩进,表示函数结束。

函数定义语法如下:

下面定义一个名为configure_intf的函数,函数有3个参数:intf_name、ip、mask。

注意事项如下。

●定义函数时的参数称为形式参数(简称形参)。

●当程序执行到定义函数的这段代码时,只是将这段代码载入内存,函数体中的代码只有在函数被调用时才执行。这类似网络设备中的访问控制列表(Access Control List,ACL)。在网络设备中创建的ACL,在应用之前,其不执行任何操作。

●调用函数时必须传入实际参数(简称实参)。

(2)函数调用

函数只有在被调用时才会被执行。要调用函数,必须使用函数名后跟圆括号的方式。调用时要根据函数的定义,提供相应个数和类型的参数,每个参数之间用逗号分隔。

下面调用函数configure_intf():

此时,函数被调用,执行函数体代码,输出如下:

当前的函数将执行结果输出到标准输出,不能保存到变量中。因为在定义函数时没有定义返回值,默认返回None。

(3)函数返回值

在Python中,用def语句创建函数时,可以用return语句指定该函数返回的值,返回值可以是任意类型的。需要注意的是,return语句在同一个函数中可以有多条,但只要有一条得到执行,就会直接结束函数的执行。

下面的代码改造了configure_intf(),将函数的输出通过return语句返回:

函数可以返回多个值。在这种情况下,它们由return后面的逗号分隔。实际上,此时函数将返回元组。例如:

也可以按照函数返回几个值就定义几个变量的方式来接收相应的返回值。

6.异常处理

程序在运行过程中,总会遇到各种各样的错误。有些错误是编写代码时造成的,有些错误是不可预料,但错误完全有可能发生的,如文件不存在、网络拥塞、系统错误等。

(1)异常

在Python中,把这些导致程序在运行过程中出现异常中断或退出的错误称为异常(Exception)。

一个程序发生异常,代表该程序在执行时出现了非正常的情况,无法再执行下去。默认情况下,程序是要终止的。如果要避免程序退出,则可以使用捕获异常的方式获取异常的名称,再通过其他的逻辑代码让程序继续运行。这种根据异常做出的逻辑处理称为异常处理。

Python定义了以下3种异常处理结构。

●try/except结构;

●try/except/else结构;

●try/except/finally结构。

(2)try/except结构

try/except结构的执行流程如下。

●首先执行try块,如果程序执行过程中出现异常,则系统会自动生成一个异常类型,并将该异常提交给Python解释器,此过程被称为捕获异常。

●Python解释器收到异常时,会寻找能处理该异常的except块。如果找到合适的except块,就把该异常交给该except块处理,此过程被称为处理异常。如果Python解释器找不到能处理异常的except块,则程序终止运行,Python解释器也将退出。

下面的代码使用了try/except结构:

(3)try/except/else结构

在try/except结构的基础上,Python异常处理机制还提供了增加一个else块的结构,即try/except/else结构。

try/except/else结构的执行流程如下。

●当try块没有捕获到任何异常时,才会执行使用else包裹的代码。

●如果try块捕获到异常,则只会执行except块中的代码处理异常,不会执行else包裹的代码。

下面的代码使用了try/except/else结构:

(4)try/except/finally结构

Python异常处理机制还提供了增加一个finally块的结构,即try/except/finally结构,在整个异常处理过程中,无论try块是否捕获到异常,最终都要进入finally块,并执行其中的代码。

下面的代码使用了try/except/finally结构: