Python 第十六章 自定义模块+time+datetime+random

自定义模块

# 1. 自定义一个模块
# import # 导入 (拿工具箱)

# 模块分类:
#     1.内置模块(标准库) -- python解释器自带的.py文件(模块)
#     2.第三方模块(各种大神写的) -- 需要额外下载的 (并发编程开始讲解) (pypi)
#     3.自定义模块(自己写的) -- 不需要额外下载

# 模块:
#     分模块的好处:
#       1.避免写重复代码
#       2.可以多次利用
#       3.拿来主义


# import test
# test.func()

# 2.导入发生的事情
# 2.1 当前的名称空间中开辟一个新的空间(test)
# 2.2 将模块中所有的代码执行
# 2.3 通过模块名.进行查找函数(工具)

# print(locals())
# import test
# print(locals())

# import test
# print(test.name)
# print(test.func())


#错误的示例:
# import test.py
# # print(test.py.func())

# import test


# import test
# import test
# import test
# import test
# import test
# print(test.name)

# import test as t
# print(t.name)


# 1.使用别名能够使文件名更短
msg = """
1.扳手
2.螺丝刀
>>>
"""
# 做一兼容性
# choose = input(msg)
# if choose == "1":
#     import meet
#     meet.func()
# elif choose == "2":
#     import test
#     test.func()



# # 做一兼容性
# choose = input(msg)
# if choose == "1":
#     import meet as t
# elif choose == "2":
#     import test as t
#
# t.func()


# import test  # 把工具箱拿过来

# from test import func
# func()

# import 和 from 的区别
# import # 把工具箱拿过来
    # 缺点:占用内存比较大
    # 优点:不会和当前文件定义的变量或者函数发生冲突

        # import test
        # name = "宝元"
        # print(test.name)
        # print(name)

# from :
#     缺点:会和当前文件定义的变量或者函数发生冲突

        # name = "宝元"
        # from test import name
        # print(name)

        # 解决方法:
            # name = "宝元"
            # from test import name as n
            # print(name)
            # print(n)

#     优点:占用内存比较小

# name = "宝元"
# def func():
#     print("is 马桶推送器")

# from test import *
# print(name)
# func()

# from test import * 会出现覆盖的现象,不能解决
# 飘红不一定是报错

# from meet import *
# print(func)
# print(name)
#
# __all__ = ["可以被导入的函数名和变量名"]

# from meet import foo
# import meet
# print(meet.foo)

# __all__ = ["可以被导入的函数名和变量名"]

# 模块导入时的坑
# name = "宝元"
# import test
# print(test.name)


# 模块的两种用法:
#     1.脚本(在cmd中执行 python test.py)
#     2.模块(不使用或者导入)

# from meet import *
# func()

# __name__ == meet

# from test import *
# if __name__ == '__main__': # 测试接口
#     func()

# 在当前模块中使用__name__ 就是 "__main__"
# 当模块被导入的时候__name__就是被导入的模块名

# 导入路径:
# import meet
# print(meet.name)

# 使用相对路径:
# from day15.t1 import meet
# print(meet.name)

# 使用绝对路径:
# 错误示例:
    # from r"D:" import meet
    # from ../

# 正确的绝对路径:
# from sys import path
# path.insert(0,"D:\")
# import meet
# print(meet.name)

# 自定义 > 内置 > 第三方

time

# time -- 时间

import time
# print(time.time())  # 时间戳 浮点数
# print(time.time() + 5000000000)  # 时间戳 浮点数
# time.sleep(3) #  睡眠         # 秒

# print(time.strftime("%Y-%m-%d %H:%M:%S"))  # 给人看的

# print(time.gmtime())  # 结构化时间 数据类型是是命名元组
# print(time.gmtime()[0])
# print(time.gmtime().tm_year)


# 将时间戳转换成字符串时间
# print(time.strftime("%Y-%m-%d %H:%M:%S",time.gmtime(1564028611.631374)))

# 将字符串时间转换成时间戳
# print(time.mktime(time.strptime("2024-3-16 12:30:30","%Y-%m-%d %H:%M:%S")))

# time重点:
# time.time()
# time.sleep()
# time.gmtime() / time.localtime() #
# time.strftime("格式化","结构化时间") #
# time.strptime("字符串","格式化")
# time.mktime()

# "2019-10-14 17:30:20"  练习题

datetime

from datetime import datetime,timedelta

# datetime -- 对象
# print(type(datetime.now()))

# print(datetime.now()) # 获取当前时间
# print(datetime(2019,5,20,15,14,00) - datetime(2019,5,20,14,20,00))

# 将当前时间转化成时间戳
# t = datetime.now()
# print(t.timestamp())

# 将时间戳转化成当前时间
# import time
# print(datetime.fromtimestamp(15000000000))

# 将字符串转成对象
# print(type(datetime.strptime("2019-10-10 22:23:24","%Y-%m-%d %H:%M:%S")))

# 将对象转成字符串
# print(str(datetime.now()))
# print(datetime.now().strftime("%Y-%m-%d %H:%M:%S"))


# datetime加减
# print(datetime.now() + timedelta(hours=30 * 24 * 12))
# print(datetime.now() - timedelta(hours=30 * 24 * 12))


# 总结:time
#     用处: 记录日志时使用
#     计算时间

random

import random

# print(random.random())          # 0 ~ 1
# print(random.uniform(1,10))     # 1 ~ 10
# print(random.randint(1,50))     # 1 ~ 50(闭区间)
# print(random.randrange(1,5,2))    # randrange(起始,终止,步长)
# print(random.choice([1,2,3,4,5,])) # 选择一个元素
# print(random.choices([1,2,3,4,5,],k=2))   # 选择两个元素,会有重复
# print(random.sample((1,2,3,4,5),k=2))  # 选择两个元素,不会有重复(除非只有两个)

# lst = [1,2,3,4,5,6,7,8,9,0]
# random.shuffle(lst)  # 顺序打乱
# print(lst)

原文地址:https://www.cnblogs.com/zhangshan33/p/11306228.html