Python:核心知识点整理大全2-笔记

简介: Python:核心知识点整理大全2-笔记

在本章中,你将学习可在Python程序中使用的各种数据,还将学 习如何将数据存储到变量中,以及如何在程序中使用这些变量。

2.1 运行 hello_world.py 时发生的情况

运行hello_world.py时,Python都做了些什么呢?下面来深入研究一下。实际上,即便是运行 简单的程序,Python所做的工作也相当多:hello_world.py

print("Hello Python world!")

运行上述代码时,你将看到如下输出:

Hello Python world!

运行文件hello_world.py时,末尾的.py指出这是一个Python程序,因此编辑器将使用Python 解释器来运行它。Python解释器读取整个程序,确定其中每个单词的含义。例如,看到单词print 时,解释器就会将括号中的内容打印到屏幕,而不会管括号中的内容是什么。 编写程序时,编辑器会以各种方式突出程序的不同部分。例如,它知道print是一个函数的 名称,因此将其显示为蓝色;它知道“Hello Python world!”不是Python代码,因此将其显示为橙 色。这种功能称为语法突出,在你刚开始编写程序时很有帮助.

第 2 章 变量和简单数据类型

2.2 变量

下面来尝试在hello_world.py中使用一个变量。在这个文件开头添加一行代码,并对第2行代 码进行修改,如下所示:

 message = "Hello Python world!"
print(message)

运行这个程序,看看结果如何。你会发现,输出与以前相同:

Hello Python world!

我们添加了一个名为message的变量。每个变量都存储了一个值——与变量相关联的信息。 在这里,存储的值为文本“Hello Python world!”。

添加变量导致Python解释器需要做更多工作。处理第1行代码时,它将文本“Hello Python world!”与变量message关联起来;而处理第2行代码时,它将与变量message关联的值打印到屏幕。

下面来进一步扩展这个程序:修改hello_world.py,使其再打印一条消息。为此,在 hello_world.py中添加一个空行,再添加下面两行代码:

 message = "Hello Python world!"
 print(message)
 message = "Hello Python Crash Course world!"
 print(message)

现在如果运行这个程序,将看到两行输出:

Hello Python world!
Hello Python Crash Course world!

在程序中可随时修改变量的值,而Python将始终记录变量的最新值。

2.2.1 变量的命名和使用

在Python中使用变量时,需要遵守一些规则和指南。违反这些规则将引发错误,而指南旨在 让你编写的代码更容易阅读和理解。请务必牢记下述有关变量的规则。

 变量名只能包含字母、数字和下划线。变量名可以字母或下划线打头,但不能以数字打 头,例如,可将变量命名为message_1,但不能将其命名为1_message。

 变量名不能包含空格,但可使用下划线来分隔其中的单词。例如,变量名greeting_message 可行,但变量名greeting message会引发错误。

 不要将Python关键字和函数名用作变量名,即不要使用Python保留用于特殊用途的单词, 如print(请参见附录A.4)。

 变量名应既简短又具有描述性。例如,name比n好,student_name比s_n好,name_length 比length_of_persons_name好。

 慎用小写字母l和大写字母O,因为它们可能被人错看成数字1和0。

要创建良好的变量名,需要经过一定的实践,在程序复杂而有趣时尤其如此。随着你编写的 程序越来越多,并开始阅读别人编写的代码,将越来越善于创建有意义的变量名。

注意 就目前而言,应使用小写的Python变量名。在变量名中使用大写字母虽然不会导致错误, 但避免使用大写字母是个不错的主意。

2.2.2 使用变量时避免命名错误

程序员都会犯错,而且大多数程序员每天都会犯错。虽然优秀的程序员也会犯错,但他们也 知道如何高效地消除错误。下面来看一种你可能会犯的错误,并学习如何消除它。 我们将有意地编写一些引发错误的代码。请输入下面的代码,包括其中以粗体显示但拼写不 正确的单词mesage:

 message = "Hello Python Crash Course reader!"
 print(mesage)

程序存在错误时,Python解释器将竭尽所能地帮助你找出问题所在。程序无法成功地运行时, 解释器会提供一个traceback。traceback是一条记录,指出了解释器尝试运行代码时,在什么地方 陷入了困境。下面是你不小心错误地拼写了变量名时,Python解释器提供的traceback:

 Traceback (most recent call last):
 1 File "hello_world.py", line 2, in <module>
 2 print(mesage)
 3 NameError: name 'mesage' is not defined

解释器指出,文件hello_world.py的第2行存在错误(见1);它列出了这行代码,旨在帮助你 快速找出错误(见2);它还指出了它发现的是什么样的错误(见3)。在这里,解释器发现了一 个名称错误,并指出打印的变量mesage未定义:Python无法识别你提供的变量名。名称错误通常 意味着两种情况:要么是使用变量前忘记了给它赋值,要么是输入变量名时拼写不正确。 在这个示例中,第2行的变量名message中遗漏了字母s。Python解释器不会对代码做拼写检查, 但要求变量名的拼写一致。例如,如果在代码的另一个地方也将message错误地拼写成了mesage, 结果将如何呢?

 mesage = "Hello Python Crash Course reader!"
 print(mesage)

在这种情况下,程序将成功地运行:

Hello Python Crash Course reader!

计算机一丝不苟,但不关心拼写是否正确。因此,创建变量名和编写代码时,你无需考虑英 语中的拼写和语法规则。 很多编程错误都很简单,只是在程序的某一行输错了一个字符。为找出这种错误而花费很长 时间的大有人在。

很多程序员天资聪颖、经验丰富,却为找出这种细微的错误花费数小时。你可 能觉得这很好笑,但别忘了,在你的编程生涯中,经常会有同样的遭遇。

注意:要理解新的编程概念,最佳的方式是尝试在程序中使用它们。如果你在做本书的练习时 陷入了困境,请尝试做点其他的事情。如果这样做后依然无法摆脱困境,请复习相关内 容。如果这样做后情况依然如故,请参阅附录C的建议。

2.3 字符串

大多数程序都定义并收集某种数据,然后使用它们来做些有意义的事情。鉴于此,对数据进 行分类大有裨益。我们将介绍的第一种数据类型是字符串。字符串虽然看似简单,但能够以很多 不同的方式使用它们。

字符串就是一系列字符。在Python中,用引号括起的都是字符串,其中的引号可以是单引号, 也可以是双引号,如下所示:

"This is a string."
'This is also a string.'

这种灵活性让你能够在字符串中包含引号和撇号:

'I told my friend, "Python is my favorite language!"'
"The language 'Python' is named after Monty Python, not the snake."
"One of Python's strengths is its diverse and supportive community." 

下面来看一些使用字符串的方式。

2.3.1 使用方法修改字符串的大小写

对于字符串,可执行的最简单的操作之一是修改其中的单词的大小写。请看下面的代码,并 尝试判断其作用:

name.py

name = "ada lovelace"
print(name.title()) 

将这个文件保存为name.py,再运行它。你将看到如下输出:

Ada Lovelace

在这个示例中,小写的字符串"ada lovelace"存储到了变量name中。在print()语句中,方法 title()出现在这个变量的后面。方法是Python可对数据执行的操作。在name.title()中,name后 面的句点(.)让Python对变量name执行方法title()指定的操作。每个方法后面都跟着一对括号, 这是因为方法通常需要额外的信息来完成其工作。这种信息是在括号内提供的。函数title()不 需要额外的信息,因此它后面的括号是空的。

title()以首字母大写的方式显示每个单词,即将每个单词的首字母都改为大写。这很有用, 因为你经常需要将名字视为信息。例如,你可能希望程序将值Ada、ADA和ada视为同一个名字, 并将它们都显示为Ada。

还有其他几个很有用的大小写处理方法。例如,要将字符串改为全部大写或全部小写,可以 像下面这样做:

name = "Ada Lovelace"
print(name.upper())
print(name.lower()) 

这些代码的输出如下:

ADA LOVELACE
ada lovelace

存储数据时,方法lower()很有用。很多时候,你无法依靠用户来提供正确的大小写,因此 需要将字符串先转换为小写,再存储它们。以后需要显示这些信息时,再将其转换为最合适的大 小写方式。

2.3.2 合并(拼接)字符串 在很多情况下,都需要合并字符串。例如,你可能想将姓和名存储在不同的变量中,等要显示姓名时再将它们合而为一:

first_name = "ada"
last_name = "lovelace"
1 full_name = first_name + " " + last_name
print(full_name)

Python使用加号(+)来合并字符串。在这个示例中,我们使用+来合并first_name、空格和 last_name,以得到完整的姓名(见1),其结果如下:

ada lovelace

这种合并字符串的方法称为拼接。通过拼接,可使用存储在变量中的信息来创建完整的消息。 下面来看一个例子:

first_name = "ada"
last_name = "lovelace"
full_name = first_name + " " + last_name
1 print("Hello, " + full_name.title() + "!")

在这里,一个问候用户的句子中使用了全名(见),并使用了方法title()来将姓名设置为 合适的格式。这些代码显示一条格式良好的简单问候语:

Hello, Ada Lovelace!

你可以使用拼接来创建消息,再把整条消息都存储在一个变量中:

first_name = "ada"
last_name = "lovelace"
full_name = first_name + " " + last_name
1 message = "Hello, " + full_name.title() + "!"
2 print(message)

上述代码也显示消息“Hello, Ada Lovelace!”,但将这条消息存储在了一个变量中(见1), 这让最后的print语句简单得多(见2)。

目录
相关文章
|
1月前
|
缓存 Java 索引
[Python]知识点
本文主要介绍了Python的一些高级知识点和使用细节,包括pip的使用、内置函数、列表、元组、字典、集合、变量、Lambda表达式、面向对象编程、异常处理、模块及标准库等。文章适合有一定Python基础的读者,重点在于深入理解和掌握Python的高级特性。文中还提供了大量示例代码,帮助读者更好地理解和应用这些知识点。
28 1
[Python]知识点
|
2月前
|
安全 Linux 数据安全/隐私保护
python知识点100篇系列(15)-加密python源代码为pyd文件
【10月更文挑战第5天】为了保护Python源码不被查看,可将其编译成二进制文件(Windows下为.pyd,Linux下为.so)。以Python3.8为例,通过Cython工具,先写好Python代码并加入`# cython: language_level=3`指令,安装easycython库后,使用`easycython *.py`命令编译源文件,最终生成.pyd文件供直接导入使用。
python知识点100篇系列(15)-加密python源代码为pyd文件
|
2月前
|
网络协议 数据库连接 Python
python知识点100篇系列(17)-替换requests的python库httpx
【10月更文挑战第4天】Requests 是基于 Python 开发的 HTTP 库,使用简单,功能强大。然而,随着 Python 3.6 的发布,出现了 Requests 的替代品 —— httpx。httpx 继承了 Requests 的所有特性,并增加了对异步请求的支持,支持 HTTP/1.1 和 HTTP/2,能够发送同步和异步请求,适用于 WSGI 和 ASGI 应用。安装使用 httpx 需要 Python 3.6 及以上版本,异步请求则需要 Python 3.8 及以上。httpx 提供了 Client 和 AsyncClient,分别用于优化同步和异步请求的性能。
python知识点100篇系列(17)-替换requests的python库httpx
|
2月前
|
调度 Python
python知识点100篇系列(20)-python协程与异步编程asyncio
【10月更文挑战第8天】协程(Coroutine)是一种用户态内的上下文切换技术,通过单线程实现代码块间的切换执行。Python中实现协程的方法包括yield、asyncio模块及async/await关键字。其中,async/await结合asyncio模块可更便捷地编写和管理协程,支持异步IO操作,提高程序并发性能。协程函数、协程对象、Task对象等是其核心概念。
|
2月前
|
Python Windows
python知识点100篇系列(24)- 简单强大的日志记录器loguru
【10月更文挑战第11天】Loguru 是一个功能强大的日志记录库,支持日志滚动、压缩、定时删除、高亮和告警等功能。安装简单,使用方便,可通过 `pip install loguru` 快速安装。支持将日志输出到终端或文件,并提供丰富的配置选项,如按时间或大小滚动日志、压缩日志文件等。还支持与邮件通知模块结合,实现邮件告警功能。
python知识点100篇系列(24)- 简单强大的日志记录器loguru
|
2月前
|
自然语言处理 Python Windows
python知识点100篇系列(23)- 使用stylecloud生成词云
【10月更文挑战第10天】`stylecloud` 是 `wordcloud` 的优化版,支持使用 Font Awesome 图标自定义词云形状,操作更简便。本文介绍如何安装 `jieba` 和 `stylecloud` 库,并使用它们生成中文词云。通过 `jieba` 进行分词,再利用 `stylecloud` 的 `gen_stylecloud` 方法生成具有特定形状和颜色的词云图像。
python知识点100篇系列(23)- 使用stylecloud生成词云
|
2月前
|
Java Python
> python知识点100篇系列(19)-使用python下载文件的几种方式
【10月更文挑战第7天】本文介绍了使用Python下载文件的五种方法,包括使用requests、wget、线程池、urllib3和asyncio模块。每种方法适用于不同的场景,如单文件下载、多文件并发下载等,提供了丰富的选择。
|
2月前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。
|
2月前
|
Java Python
python知识点100篇系列(16)-python中如何获取线程的返回值
【10月更文挑战第3天】本文介绍了两种在Python中实现多线程并获取返回值的方法。第一种是通过自定义线程类继承`Thread`类,重写`run`和`join`方法来实现;第二种则是利用`concurrent.futures`库,通过`ThreadPoolExecutor`管理线程池,简化了线程管理和结果获取的过程,推荐使用。示例代码展示了这两种方法的具体实现方式。
python知识点100篇系列(16)-python中如何获取线程的返回值
|
2月前
|
Python
python知识点100篇系列(14)-分割大文件然后在合并
【10月更文挑战第2天】在工作中,因邮件附件大小限制或网络条件不佳,常需将大文件分割为小文件发送,接收后再合并。Python的文件读写功能可轻松实现此需求,也可借助第三方库filesplit简化操作。安装filesplit后,仅需几行代码即可完成文件的分割与合并,但掌握Python内置方法同样重要。