Lesson 1-2

时间:2023-03-08 21:12:03
Lesson 1-2

1.5 模块

  模块可视为扩展,通过将其导入可以扩展python的功能。python中自带有一组模块,也称为“标准库”。

1.5.1 模块的导入:import + 模块名称

• 使用关键字import导入模块

• import之后跟模块名称,可一次导入多个模块,多个模块名称之间使用逗号隔开

• 使用“模块名称.函数名称”的方式来调用该模块中的函数

 >>> import random,math
>>> print(random.randint(1,10))
3
>>> print(math.floor(3.7))
3
>>>

1.5.2 模块的导入:from 模块名称 import *

• 使用关键字from,import和 * 号

• 直接使用“函数名称”的方式来调用该模块中的函数

• 使用该方式虽然简化了调用方式,但是代码可读性变差,且必须确认没有同名函数

 >>> from math import *
>>> ceil(33.3)
34
>>> sqrt(25)
5.0
>>>

1.5.3 模块的导入:from 模块名称 import 函数名称

• 使用1.5.2导入方式模块中的所有函数都可以调用,而该方式区别在于指定导入模块中的函数名称,只可以调用该函数,模块中的其它函数不可调用,强行调用则会出现‘“函数未定义”的报错

• 该方式适用于明确只使用该模块中的指定函数

 >>> from math import ceil
>>> ceil(33.3)
34
>>> sqrt(25)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'sqrt' is not defined
>>>

1.5.4 模块的导入:使用 as 关键字

  模块导入时可以通过使用 as 关键字来改变相应的引用对象名字,适用于模块名称或者函数名称过长过复杂时的简化。

• 例如使用 import random as r ,则在后续的调用中可用“r”代替“random” 。

 >>> import random as r
>>> r.randint(1,10)
1
>>>

• 例如使用 from random import randint as r ,则在后续的调用中可用“r”代替“randint” 。

 >>> from random import randint as r
>>> r(1,10)
5
>>>

1.6 注释

--- 在python中,使用井号(#)来进行注释,# 到行尾的内容将被当成注释

--- 特殊的例子是脚本的第一行字符序列:#!+ python的绝对路径 + python可执行程序名 ,例如:#!/usr/bin/python3.7  python3

--- 可使用一对单三引号(‘’‘)或者一对双三引号(“”“)进行多行(段落)注释

--- 注释必须言而有物,无用而重复的注释还不如没有

1.7 简单的字符串

1.7.1 长字符串

--- 常规字符串也可以跨越多行,只要在行尾加上反斜杠,python自动进行拼接

 >>> "Hello \
... world!"
'Hello world!'
>>> print("Hello \
... world!")
Hello world!
>>>

--- 使用三单引号或三双引号表示很长的多行字符串,python不会自动进行拼接

 >>> print("""Hello
... world
... !""")
Hello
world
!
>>>

1.7.2 原始字符串

--- 原始字符串使用前缀 r 表示,r 后的字符串可使用单引号、双引号、三引号括起来,但该字符串不能以单个反斜杠结尾

 >>> print("Hello \nworld!")
Hello
world!
>>> print(r"Hello \nworld!")
Hello \nworld!
>>> print(r"Hello \nworld!\")
File "<stdin>", line 1
print(r"Hello \nworld!\")
^
SyntaxError: EOL while scanning string literal
>>>

1.8 简单的字符编码

--- 内存和磁盘中所有对象都是以二进制表示,python提供不可变bytes和可变bytearray两种类型来对接,bytes类型可直接创建bytes对象。

 >>> "Hello world!"
'Hello world!'
>>> b"Hello world!"
b'Hello world!'
>>> type('Hello world!')
<class 'str'>
>>> type(b'Hello world!')
<class 'bytes'>
>>>

--- 将文本到内存和磁盘文件中,需要进行编码,编码使用encode函数;将文本从内存和磁盘文件中出,需要进行解码,解码使用decode函数。

--- 使用ASCII、UTF-8、UTF-32编码将字符串转换为bytes

 >>> "Hello world!".encode("ASCII")
b'Hello world!'
>>> "Hello world!".encode("UTF-8")
b'Hello world!'
>>> "Hello world!".encode("UTF-32")
b'\xff\xfe\x00\x00H\x00\x00\x00e\x00\x00\x00l\x00\x00\x00l\x00\x00\x00o\x00\x00\x00 \x00\x00\x00w\x00\x00\x00o\x00\x00\x00r\x00\x00\x00l\x00\x00\x00d\x00\x00\x00!\x00\x00\x00'
>>>

--- 编码长度

 >>> len("Hello world!".encode("ASCII"))
12
>>> len("Hello world!".encode("UTF-8"))
12
>>> len("Hello world!".encode("UTF-32"))
52
>>>

--- 最好使用UTF-8编码,UTF-8也是默认使用的编码。