模块及时间模块

模块

把所有的定义存放在文件中,为一些脚本或者交互式的解释器实例使用,这个文件被称为模块(Module)
模块是一个包含所有定义的函数和变量的文件,其后缀名是.py。模块可以被别的程序引入,以使用该模块中的函数等功能。这也是使用Python标准库的方法

1、什么是模块

1)容器→数据的封装
2)函数→语句的封装
3)类→方法和属性的封装
4)模块→程序文件

# hello.py
def hi():
    print('Hi everyone, I love lsgogroup!')

2、命名空间

命名空间因为对象的不同,也有所区别,分为以下几种:
1)内置命名空间(Built-in Namespaces)
Python运行起来,它们就存在了。内置函数的命名空间都属于内置命名空间,所以可以在任何程序中直接使用它们,比如id(),不需要做什么动作,拿过来就直接使用了
2)全局命名空间(Module:Global Namespaces)
每个模块创建它自己所拥有的全局命名空间,不同模块的全局命名空间彼此独立,不同模块中相同名称的命名空间,也会因为模块的不同而不相互干扰。
3)本地命名空间(Function&Class: Local Namespaces)
模块中有函数或者类,每个函数或者类所定义的命名空间就是本地命名空间。如果函数返回了结果或者抛出异常,则本地命名空间也结束了。

4)程序在查询上述三种命名空间的时候,就按照从里到外的顺序,即:
Local Nmaespaces → Global Namesspaces → Built-in Namespaces

import hello
hello.hi()
---------------------------------------------------------------------------

ModuleNotFoundError                       Traceback (most recent call last)

<ipython-input-1-dccd81507c8d> in <module>
----> 1 import hello
      2 hello.hi()


ModuleNotFoundError: No module named 'hello'

3、导入模块

# 创建一个模块TemperatureConversion.py

#TmeperatureConversion.py
def c2f(cel):
    fah = cel * 1.8 + 32
    return fah

def f2c(fah):
    cel = (fah - 32) / 1.8
    return cel


#第一种:import 模块名
import TemperatureConversion

print('32摄氏度 = %.2f华氏度' % TemperatureConversion.c2f(32))
print('99华氏度 = %.2f摄氏度' % TemperatureConversion.f2c(99))

#第二种:from 模块名 import 函数名
from TemperatureConversion import c2f , f2c
print('32摄氏度 = %.2f华氏度' % c2f(32))
print('99华氏度 = %.2f摄氏度' % f2c(99))

#以下方式不推荐
from TemperatureConversion import *
print('32摄氏度 = %.2f华氏度' % c2f(32))
print('99华氏度 = %.2f摄氏度' % f2c(99))

#第三种:import 模块名字 as 新名字
import TemperatureConversion as tc
print('32摄氏度 = %.2f华氏度' % tc.c2f(32))
print('99华氏度 = %.2f摄氏度' % tc.f2c(99))
  File "<ipython-input-3-5c32223adb76>", line 20
    from TemperatureConversion imoprt c2f , f2c
                                    ^
SyntaxError: invalid syntax

4、if name == ‘main

对于很多编程语言来说程序都必须有一个入口
Python不同,它属于脚本语言,不像编译型语言那样先将程序编译成二进制再运行,二十动态的逐行解释运行。也就是从脚本第一行开始运行,没有统一的入口。

#假设有一个const.py文件,内容如下:
PI = 3.14

def main():
    print("PI:",PI)

main()

#现在写一个用于计算圆面积的area.py文件,需用到const.py文件中的PI变量。从const.py中,把PI变量导入area.py:
from const import PI

def calc_round_area(radius):
    return PI*(radius ** 2)

def main():
    print("round area:",cal_round_area(2))

main()

"""
我们看到const.py中的main函数也被运行了,实际上我们不希望它被运行,因为const.py提供的main函数只是为了测试常量定义
这是if __name__ =='__main__'排上了用场,我们把const.py改一下,添加 if __name__ == "__main__"
"""
PI = 3.14

def main():
    print("PI:",PI)

if __name__ == "__main__":
    main()
    
#运行oncst.py,输出如下

#运行area.py,输出如下

#__name__: 是内置变量,可用于表示当前模块的名字

import const
print(__name__)
print(const.__name__)

"""
由此可知,如果一个.py文件(模块)被直接运行时,其__name__的值为__main__,即模块名为__main__。
所以,if __name__ == '__main__'的意思时,当.py文件被直接运行时,if__name__ ='__main__'之下的代码将被运行
当.py文件以模块形式被导入时,if __name__ == '__main__'之下的代码块不被运行
"""
PI: 3.14



---------------------------------------------------------------------------

ModuleNotFoundError                       Traceback (most recent call last)

<ipython-input-5-ba39f86e510f> in <module>
      8 
      9 #现在写一个用于计算圆面积的area.py文件,需用到const.py文件中的PI变量。从const.py中,把PI变量导入area.py:
---> 10 from const import PI
     11 
     12 def calc_round_area(radius):


ModuleNotFoundError: No module named 'const'

5、搜索路径

#当解释器遇到Import语句,如果模块再当前的搜索路径就会被导入
import sys
print(sys.path)

['C:\\Users\\dtdai\\Datawhale Python', 'D:\\study\\anaconda\\python37.zip', 'D:\\study\\anaconda\\DLLs', 'D:\\study\\anaconda\\lib', 'D:\\study\\anaconda', '', 'D:\\study\\anaconda\\lib\\site-packages', 'D:\\study\\anaconda\\lib\\site-packages\\win32', 'D:\\study\\anaconda\\lib\\site-packages\\win32\\lib', 'D:\\study\\anaconda\\lib\\site-packages\\Pythonwin', 'D:\\study\\anaconda\\lib\\site-packages\\IPython\\extensions', 'C:\\Users\\dtdai\\.ipython']

我们使用 import 语句的时候,Python 解释器是怎样找到对应的文件的呢?
这就涉及到 Python 的搜索路径,搜索路径是由一系列目录名组成的,Python 解释器就依次从这些目录中去寻找所引入的模块。
这看起来很像环境变量,事实上,也可以通过定义环境变量的方式来确定搜索路径。
搜索路径是在 Python 编译或安装的时候确定的,安装新的库应该也会修改。搜索路径被存储在 sys 模块中的 path 变量中。

6、包(package)

包是一种管理 Python 模块命名空间的形式,采用"点模块名称"。
创建包分为三个步骤:
1)创建一个文件夹,用于存放相关的模块,文件夹的名字即包的名字。
2)在文件夹中创建一个 init.py 的模块文件,内容可以为空。
3)将相关的模块放入文件夹中。
不妨假设你想设计一套统一处理声音文件和数据的模块(或者称之为一个"包")。
现存很多种不同的音频文件格式(基本上都是通过后缀名区分的,例如: .wav,.aiff,.au),所以你需要有一组不断增加的模块,用来在不同的格式之间转换。
并且针对这些音频数据,还有很多不同的操作(比如混音,添加回声,增加均衡器功能,创建人造立体声效果),所以你还需要一组怎么也写不完的模块来处理这些操作。
这里给出了一种可能的包结构(在分层的文件系统中):
sound/ 顶层包
init.py 初始化 sound 包
formats/ 文件格式转换子包
init.py
wavread.py
wavwrite.py
aiffread.py
aiffwrite.py
auread.py
auwrite.py

effects/ 声音效果子包
init.py
echo.py
surround.py
reverse.py

filters/ filters 子包
init.py
equalizer.py
vocoder.py
karaoke.py

在导入一个包的时候,Python 会根据 sys.path 中的目录来寻找这个包中包含的子目录。
目录只有包含一个叫做 init.py 的文件才会被认作是一个包,最简单的情况,放一个空的 init.py 就可以了。
import sound.effects.echo
这将会导入子模块 sound.effects.echo。 他必须使用全名去访问:
sound.effects.echo.echofilter(input, output, delay=0.7, atten=4)
还有一种导入子模块的方法是:
from sound.effects import echo
这同样会导入子模块: echo,并且他不需要那些冗长的前缀,所以他可以这样使用:
echo.echofilter(input, output, delay=0.7, atten=4)
还有一种变化就是直接导入一个函数或者变量:
from sound.effects.echo import echofilter
同样的,这种方法会导入子模块: echo,并且可以直接使用他的 echofilter() 函数:
echofilter(input, output, delay=0.7, atten=4)
注意当使用 from package import item 这种形式的时候,对应的 item 既可以是包里面的子模块(子包),或者包里面定义的其他名称,比如函数,类或者变量。
设想一下,如果我们使用 from sound.effects import * 会发生什么?
Python 会进入文件系统,找到这个包里面所有的子模块,一个一个的把它们都导入进来。
导入语句遵循如下规则:如果包定义文件 init.py 存在一个叫做 all 的列表变量,那么在使用 from package import * 的时候就把这个列表中的所有名字作为包内容导入。
这里有一个例子,在 sounds/effects/init.py中包含如下代码:
all = [“echo”, “surround”, “reverse”]
这表示当你使用 from sound.effects import *这种用法时,你只会导入包里面这三个子模块。
如果 all 真的没有定义,那么使用from sound.effects import *这种语法的时候,就不会导入包 sound.effects 里的任何子模块。他只是把包 sound.effects 和它里面定义的所有内容导入进来(可能运行__init__.py里定义的初始化代码)。
这会把 init.py 里面定义的所有名字导入进来。并且他不会破坏掉我们在这句话之前导入的所有明确指定的模块。
import sound.effects.echo
import sound.effects.surround
from sound.effects import *
这个例子中,在执行 from…import 前,包 sound.effects 中的 echo 和 surround 模块都被导入到当前的命名空间中了。
通常我们并不主张使用 * 这种方法来导入模块,因为这种方法经常会导致代码的可读性降低。

二、datetime模块

datetime时Python中处理日期的标准模块,它提供了4中对日期和时间进行处理的类:datetime、date、time、timedelta

1、datetime类

class datetime(date):
    def __init__(self,year,month,day,hour,minute,second,microsecond,tzinfo)
        pass
    def now(cls, tz=None):
        pass
    # datetime.now(tz=None)获取当前的日期时间,输出顺序为:年、月、日、时、分、秒、微秒
    def timestamp(self):
        pass
    #datetime.timestamp()获取以1970年1月1日为起点记录的秒数
    def fromtimestamp(cls,t,tz=None)
        pass
    #datetime.fromtimestamp(tz=None)使用unixtimestamp创建一个datetime
    def date(self):
        pass
    def time(self):
        pass
    def year(self):
        pass
    def month(self):
        pass
    def day(self):
        pass
    def hour(self):
        pass
    def second(self):
        pass
    def isoweekday(self):
        pass
    def strftime(self):
        pass
    def combine(cls,date,time,tzinfo=True):
        pass
#如何创建一个datetime对象
import datetime

dt = datetime.datetime(year=2020,month=6,day=25,hour=11,minute=23,second=59)
print(dt)
print(dt.timestamp())

dt = datetime.datetime.fromtimestamp(1593055439.0)
print(dt)
print(type(dt))

dt = datetime.datetime.now()
print(dt)
print(type(dt))
2020-06-25 11:23:59
1593055439.0
2020-06-25 11:23:59
<class 'datetime.datetime'>
2020-08-07 23:49:39.585504
<class 'datetime.datetime'>

2、date类

3、time类

4、timedelta类






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值