30.从入门到精通:Python3 命名空间和作用域 命名空间 作用域 Python3 标准库概览 操作系统接口 文件通配符 命令行参数 错误输出重定向和程序终止 字符串正则匹配 访问 互联网 日期和

简介: 30.从入门到精通:Python3 命名空间和作用域 命名空间 作用域 Python3 标准库概览 操作系统接口 文件通配符 命令行参数 错误输出重定向和程序终止 字符串正则匹配 访问 互联网 日期和

Python3 命名空间和作用域

命名空间

在Python中,命名空间是指用于存储变量名称和其对应值的区域。每个命名空间都有一个唯一的名称,并且在不同的命名空间中可以使用相同的变量名称,而不会互相干扰。

Python中有以下几种命名空间:

内置命名空间(built-in namespace):包含了Python解释器内置的函数和变量,例如print()函数和int类型。

全局命名空间(globalnamespace):在模块中定义的变量和函数属于全局命名空间。在模块中定义的变量和函数可以在模块中的任何位置访问。

局部命名空间(local namespace):在函数内部定义的变量和函数属于局部命名空间。在函数内部定义的变量和函数只能在函数内部访问。

当Python解释器遇到一个变量时,它会按照以下顺序查找命名空间:

1.首先查找局部命名空间,如果变量在局部命名空间中找到,则使用该变量。

2.如果变量不在局部命名空间中,则查找全局命名空间。如果变量在全局命名空间中找到,则使用该变量。

3.如果变量不在全局命名空间中,则查找内置命名空间。如果变量在内置命名空间中找到,则使用该变量。

4.如果变量在任何一个命名空间中都没有找到,则会引发NameError异常。


需要注意的是,当在函数内部访问一个变量时,Python解释器会首先查找局部命名空间,如果该变量在局部命名空间中不存在,则会查找全局命名空间。如果该变量在全局命名空间中也不存在,则会引发NameError异常。


作用域

Python3中有两种作用域,分别是全局作用域和局部作用域。

全局作用域是指在整个程序中都可以访问的变量,一般定义在程序的最外层。在函数内部可以通过global关键字来声明一个变量为全局变量。

  • 局部作用域是指在函数内部定义的变量,只能在函数内部访问。当函数执行完毕后,局部变量的作用域也就结束了。在函数内部可以通过nonlocal关键字来声明一个变量为非局部变量,即在嵌套函数中访问外层函数的变量。

在Python3中,变量的作用域遵循LEGB规则,即Local(局部)、Enclosing(嵌套)、Global(全局)、Built-in(内置)的顺序。当在函数内部访问一个变量时,Python3会按照这个顺序查找变量的值。例如,如果在函数内部访问一个变量,Python3会首先查找局部作用域中是否存在这个变量,如果不存在,则查找嵌套作用域中是否存在这个变量,如果还不存在,则查找全局作用域中是否存在这个变量,最后查找内置作用域中是否存在这个变量。如果在所有作用域中都找不到这个变量,Python3会抛出NameError异常。


Python3 标准库概览

Python标准库是Python语言的核心部分之一,它提供了许多有用的模块和函数,可以用于各种不同的任务。以下是Python标准库的一些常用模块和函数的概述:

os模块:提供了与操作系统交互的函数,例如文件操作、进程管理等。

sys模块:提供了与Python解释器交互的函数,例如命令行参数、标准输入输出等。

re模块:提供了正则表达式操作的函数。

datetime模块:提供了日期和时间操作的函数。

random模块:提供了生成随机数的函数。

math模块:提供了数学函数,例如三角函数、指数函数等。

json模块:提供了JSON编码和解码的函数。

urllib模块:提供了HTTP请求的函数。

sqlite3模块:提供了SQLite数据库的函数。

csv模块:提供了CSV文件读写的函数。


以上只是Python标准库中的一小部分,还有许多其他有用的模块和函数,可以根据需要选择使用。可以通过Python官方文档查看完整的标准库文档。


操作系统接口

操作系统接口是指操作系统提供给应用程序或用户的一组功能和服务,用于访问和管理计算机硬件和软件资源。操作系统接口可以分为以下几类:


文件系统接口:用于管理文件和目录,包括创建、删除、移动、复制、重命名等操作。

进程管理接口:用于管理进程,包括创建、终止、调度、同步、通信等操作。

内存管理接口:用于管理计算机内存,包括分配、释放、保护、共享等操作。

设备管理接口:用于管理计算机硬件设备,包括初始化、读写、控制、中断处理等操作。

网络管理接口:用于管理计算机网络,包括连接、断开、传输、协议处理等操作。


不同的操作系统提供的接口可能有所不同,但是它们都提供了一定程度的标准化接口,以便应用程序能够在不同的操作系统上运行。例如,POSIX接口是一组标准化的操作系统接口,可以在Unix和类Unix操作系统上使用。而Windows操作系统提供的接口则是基于Win32

API和.NET Framework的。


文件通配符

文件通配符是一种用于匹配文件名的模式,通常用于在命令行中指定一组文件。在Unix和类Unix操作系统中,文件通配符通常使用shell扩展来实现。

以下是常用的文件通配符:

  • *:匹配任意字符,包括空字符。
  • ?:匹配任意单个字符。
  • […]:匹配括号内的任意一个字符。例如,[abc]可以匹配字符a、b或c。
  • […]:匹配不在括号内的任意一个字符。例如,[abc]可以匹配除了字符a、b和c之外的任意字符。


例如,如果要匹配所有以.txt结尾的文件,可以使用通配符*.txt。如果要匹配所有以数字开头的文件,可以使用通配符[0-9]。

在Python中,可以使用glob模块来实现文件通配符匹配。例如,glob.glob('.txt’)可以匹配当前目录下所有以.txt结尾的文件。


命令行参数

在计算机程序中,命令行参数是指在程序启动时,从命令行传递给程序的一组参数。这些参数可以用来控制程序的行为,或者传递程序需要的数据。

  • 在Python中,可以使用sys模块中的argv变量来获取命令行参数。argv变量是一个列表,其中第一个元素是程序本身的名称,后面的元素是传递给程序的命令行参数。.

例如,下面是一个简单的Python程序,可以接受两个命令行参数并将它们相加:

import sys
if len(sys.argv) != 3:
    print("Usage: python program.py arg1 arg2")
else:
    arg1 = int(sys.argv[1])
    arg2 = int(sys.argv[2])
    print(arg1 + arg2)

在这个程序中,首先检查命令行参数的数量是否为3,如果不是,则打印出程序的使用方法。如果命令行参数的数量正确,则将第一个和第二个参数转换为整数,并将它们相加,然后输出结果。

可以在命令行中运行这个程序,例如:

python program.py 2 3

这将输出5,因为程序将2和3相加。


错误输出重定向和程序终止

在Python中,可以使用错误输出重定向来将错误信息输出到指定的文件或设备,而不是默认输出到屏幕上。

以下是将错误输出重定向到文件的示例:

import sys
try:
    # some code that may raise an exception
    pass
except Exception as e:
    # redirect error output to a file
    sys.stderr = open('error.log', 'w')
    print('An error occurred:', e)
    # restore error output to the default value
    sys.stderr = sys.__stderr__

在上面的代码中,我们使用sys.stderr将错误输出重定向到error.log文件中,然后打印错误信息。最后,我们将错误输出恢复为默认值。


如果程序遇到无法处理的错误,可以使用sys.exit()函数来终止程序的执行。该函数接受一个可选的整数参数,表示程序的退出状态码。通常,0表示程序正常退出,非零值表示程序异常终止。

以下是一个示例:

import sys
try:
    # some code that may raise an exception
    pass
except Exception as e:
    print('An error occurred:', e)
    sys.exit(1)  # exit with error status

在上面的代码中,如果程序遇到异常,它将打印错误信息并以状态码1退出。


字符串正则匹配

在Python中,可以使用re模块进行字符串正则匹配。re模块提供了一组函数,用于在字符串中搜索和匹配模式。

下面是一个简单的例子,说明如何使用re模块进行字符串正则匹配:

import re
# 定义一个正则表达式
pattern = r"hello\s+(\w+)"
# 定义一个字符串
string = "hello world, hello python, hello java"
# 使用正则表达式进行匹配
result = re.findall(pattern, string)
# 输出匹配结果
print(result)

在这个例子中,首先定义了一个正则表达式,它表示以"hello

"开头,后面跟着一个或多个空格,然后是一个单词。然后定义了一个字符串,其中包含了多个符合这个模式的子串。接下来使用re模块中的findall函数进行匹配,它会返回一个列表,其中包含了所有符合模式的子串。最后输出匹配结果,可以看到输出的结果是一个列表,其中包含了所有匹配到的单词。

除了findall函数之外,re模块还提供了其他一些函数,用于进行字符串正则匹配,例如search函数、match函数、sub函数等等。这些函数的具体用法和参数可以查看Python官方文档。


访问 互联网

要访问互联网,可以使用Python内置的urllib模块。urllib模块提供了一组函数,用于处理URL和HTTP请求。

下面是一个简单的例子,说明如何使用urllib模块访问一个网页:

import urllib.request
# 要访问的网页URL
url = "https://www.baidu.com"
# 发送HTTP请求,获取响应
response = urllib.request.urlopen(url)
# 读取响应内容
html = response.read()
# 输出网页内容
print(html)

在这个例子中,首先定义了一个要访问的网页URL。然后使用urllib.request.urlopen函数发送HTTP请求,获取响应。最后读取响应内容,并输出网页内容。

除了urllib模块之外,还可以使用第三方库requests来访问互联网。requests库提供了更加简洁和方便的API,可以更加方便地发送HTTP请求和处理响应。

下面是一个使用requests库访问网页的例子:

import requests
# 要访问的网页URL
url = "https://www.baidu.com"
# 发送HTTP请求,获取响应
response = requests.get(url)
# 读取响应内容
html = response.text
# 输出网页内容
print(html)
  • 在这个例子中,首先定义了一个要访问的网页URL。然后使用requests库中的get函数发送HTTP请求,获取响应。最后读取响应内容,并输出网页内容。

需要注意的是,访问互联网可能会受到网络环境和访问权限的限制,有些网站可能需要登录或者使用代理才能访问。另外,访问互联网还需要注意遵守相关法律法规和网站的使用规定。


日期和时间

在Python中,可以使用datetime模块来处理日期和时间。
下面是一些常见的日期和时间操作:

获取当前日期和时间:

import datetime
now = datetime.datetime.now()
print(now)

这将输出当前日期和时间,例如:

2021-08-12 14:23:50.123456

格式化日期和时间:

import datetime
now = datetime.datetime.now()
formatted = now.strftime("%Y-%m-%d %H:%M:%S")
print(formatted)

这将输出格式化后的日期和时间,例如:

2021-08-12 14:23:50

在这个例子中,使用strftime函数将日期和时间格式化为指定的字符串。

计算日期和时间的差值:

import datetime
start = datetime.datetime(2021, 8, 1)
end = datetime.datetime.now()
delta = end - start
print(delta)

这将输出两个日期和时间之间的差值,例如:

11 days, 14:23:50.123456

在这个例子中,首先定义了两个日期和时间,然后使用减法运算符计算它们之间的差值。


除了这些基本操作之外,datetime模块还提供了许多其他的日期和时间操作,例如时区转换、日期和时间的加减、日期和时间的比较等等。可以查看Python官方文档了解更多信息。


相关实践学习
CentOS 7迁移Anolis OS 7
龙蜥操作系统Anolis OS的体验。Anolis OS 7生态上和依赖管理上保持跟CentOS 7.x兼容,一键式迁移脚本centos2anolis.py。本文为您介绍如何通过AOMS迁移工具实现CentOS 7.x到Anolis OS 7的迁移。
相关文章
|
4天前
|
自然语言处理 运维 前端开发
OS Copilot-操作系统智能助手-新手小白入门必选~
作为一名安卓开发工程师,我日常专注于前端和移动端开发。然而,在项目推进中偶尔需要部署服务端,这对不熟悉Linux的我来说颇具挑战。每次用命令行工具操作时,常需频繁查阅命令及参数,效率低下。 幸运的是,我发现了阿里云推出的OS Copilot智能助手。它通过自然语言问答功能,让命令行操作变得轻松流畅,帮助我快速定位并解决问题,显著提升了工作效率。安装简单,配置便捷,支持单命令模式和命令行模式,极大简化了Linux操作,成为我得力的开发利器。 总结而言,OS Copilot让我这个Linux小白也能高效处理服务端任务,操作体验焕然一新,是不可多得的智能助手。
|
2月前
|
Python
在 Python 中,如何将日期时间类型转换为字符串?
在 Python 中,如何将日期时间类型转换为字符串?
131 64
|
1月前
|
存储 测试技术 Python
Python 中别再用 ‘+‘ 拼接字符串了!
通过选择合适的字符串拼接方法,可以显著提升 Python 代码的效率和可读性。在实际开发中,根据具体需求和场景选择最佳的方法,避免不必要的性能损失。
51 5
|
1月前
|
Python
使用Python计算字符串的SHA-256散列值
使用Python计算字符串的SHA-256散列值
49 7
|
2月前
|
Python
在 Python 中,如何将字符串中的日期格式转换为日期时间类型?
在 Python 中,如何将字符串中的日期格式转换为日期时间类型?
44 6
|
2月前
|
Python
文件元数据获取方法对比:`os.path` 与 `os.stat`
本文对比了Python中两种获取文件元数据的方法:`os.path`和`os.stat`。通过示例代码展示了如何获取文件大小和修改时间,并从性能、功能性和代码可读性三方面进行了详细对比。最终给出了根据具体需求选择合适方法的最佳实践建议。
35 2
|
3月前
|
Windows Python
【10月更文挑战第2天】「Mac上学Python 2」入门篇2 - 开发环境命令行操作与文件管理
本篇将详细介绍Windows和Mac系统中的常用命令行操作与文件管理,帮助用户掌握如何通过终端或命令提示符进行文件管理和操作开发环境。内容涵盖路径切换、文件与文件夹的创建、删除、查看文件内容等基本操作,这些技能是后续Python开发的基础。
145 6
【10月更文挑战第2天】「Mac上学Python 2」入门篇2 - 开发环境命令行操作与文件管理
|
3月前
|
Python
【10月更文挑战第6天】「Mac上学Python 11」基础篇5 - 字符串类型详解
本篇将详细介绍Python中的字符串类型及其常见操作,包括字符串的定义、转义字符的使用、字符串的连接与格式化、字符串的重复和切片、不可变性、编码与解码以及常用内置方法等。通过本篇学习,用户将掌握字符串的操作技巧,并能灵活处理文本数据。
65 1
【10月更文挑战第6天】「Mac上学Python 11」基础篇5 - 字符串类型详解
|
3月前
|
自然语言处理 Java 数据处理
【速收藏】python字符串操作,你会几个?
【速收藏】python字符串操作,你会几个?
72 7
|
3月前
|
存储 安全 Serverless
Python学习四:流程控制语句(if-else、while、for),高级数据类型(字符串、列表、元组、字典)的操作
这篇文章主要介绍了Python中的流程控制语句(包括if-else、while、for循环)和高级数据类型(字符串、列表、元组、字典)的操作。
53 0