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的迁移。
相关文章
|
6天前
|
机器学习/深度学习 数据挖掘 Python
Python编程入门——从零开始构建你的第一个程序
【10月更文挑战第39天】本文将带你走进Python的世界,通过简单易懂的语言和实际的代码示例,让你快速掌握Python的基础语法。无论你是编程新手还是想学习新语言的老手,这篇文章都能为你提供有价值的信息。我们将从变量、数据类型、控制结构等基本概念入手,逐步过渡到函数、模块等高级特性,最后通过一个综合示例来巩固所学知识。让我们一起开启Python编程之旅吧!
|
6天前
|
存储 Python
Python编程入门:打造你的第一个程序
【10月更文挑战第39天】在数字时代的浪潮中,掌握编程技能如同掌握了一门新时代的语言。本文将引导你步入Python编程的奇妙世界,从零基础出发,一步步构建你的第一个程序。我们将探索编程的基本概念,通过简单示例理解变量、数据类型和控制结构,最终实现一个简单的猜数字游戏。这不仅是一段代码的旅程,更是逻辑思维和问题解决能力的锻炼之旅。准备好了吗?让我们开始吧!
|
8天前
|
机器学习/深度学习 数据挖掘 开发者
Python编程入门:理解基础语法与编写第一个程序
【10月更文挑战第37天】本文旨在为初学者提供Python编程的初步了解,通过简明的语言和直观的例子,引导读者掌握Python的基础语法,并完成一个简单的程序。我们将从变量、数据类型到控制结构,逐步展开讲解,确保即使是编程新手也能轻松跟上。文章末尾附有完整代码示例,供读者参考和实践。
|
18天前
|
机器学习/深度学习 算法 编译器
Python程序到计算图一键转化,详解清华开源深度学习编译器MagPy
【10月更文挑战第26天】MagPy是一款由清华大学研发的开源深度学习编译器,可将Python程序一键转化为计算图,简化模型构建和优化过程。它支持多种深度学习框架,具备自动化、灵活性、优化性能好和易于扩展等特点,适用于模型构建、迁移、部署及教学研究。尽管MagPy具有诸多优势,但在算子支持、优化策略等方面仍面临挑战。
48 3
|
20天前
|
算法 测试技术 开发者
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗
在Python开发中,性能优化和代码审查至关重要。性能优化通过改进代码结构和算法提高程序运行速度,减少资源消耗;代码审查通过检查源代码发现潜在问题,提高代码质量和团队协作效率。本文介绍了一些实用的技巧和工具,帮助开发者提升开发效率。
21 3
|
23天前
|
存储 人工智能 数据挖掘
Python编程入门:构建你的第一个程序
【10月更文挑战第22天】编程,这个听起来高深莫测的词汇,实际上就像搭积木一样简单有趣。本文将带你走进Python的世界,用最浅显的语言和实例,让你轻松掌握编写第一个Python程序的方法。无论你是编程新手还是希望了解Python的爱好者,这篇文章都将是你的理想起点。让我们一起开始这段奇妙的编程之旅吧!
20 3
|
1月前
|
弹性计算 开发框架 .NET
阿里云服务器购买教程及云服务器地域、实例、操作系统、带宽等参数选择指南
对于初次购买阿里云服务器的用户来说,想使用阿里云服务器搭建网站或者运行APP、小程序等项目,第一步就是要先购买阿里云服务器,下面小编以图文形式给大家介绍一下阿里云服务器的购买流程,以及购买过程中如何云服务器地域、实例、带宽等关键配置和选择这些参数的一些注意事项,以供参考。
|
1月前
|
IDE 开发工具 Python
Python 编程入门:打造你的第一个程序
【10月更文挑战第6天】编程,这个听起来高大上又充满神秘感的领域,其实就像学习骑自行车一样。一开始你可能会觉得难以掌握平衡,但一旦你学会了,就能自由地穿梭在广阔的道路上。本文将带你走进 Python 的世界,用最简单的方式让你体验编写代码的乐趣。不需要复杂的理论,我们将通过一个简单的例子——制作一个猜数字游戏,来实践学习。准备好了吗?让我们开始吧!
|
13天前
|
存储 机器学习/深度学习 搜索推荐
Python编程入门:从零开始构建你的第一个程序
【10月更文挑战第32天】本文旨在通过浅显易懂的方式引导编程新手进入Python的世界。我们将一起探索Python的基础语法,并通过实例学习如何构建一个简单的程序。文章将不直接展示代码,而是鼓励读者在阅读过程中自行尝试编写,以加深理解和记忆。无论你是编程初学者还是希望巩固基础知识的开发者,这篇文章都将是你的良师益友。让我们开始吧!
|
1月前
|
存储 JSON 安全
面向企业应用程序的 Python 配置管理
面向企业应用程序的 Python 配置管理
28 9

热门文章

最新文章