概要
パッケージ
ファイルを分離するために使用される、またはドキュメントのモジュールを1つだけ持っていたか、オンデマンドで割ったモジュール(機能)内で機能するためには、それを提出されたパケットの役割を理解するのは簡単です、機能が異なる内に配置されたのと同じタイプ(機能)のものであろうファイルまたはモジュール(パッケージ)モジュール(内部の新しいファイルフォルダに基づいています)
パッケージ、モジュールが同じように導入した後、パッケージを使用するのと同じ方法を複数に導入され、ユーザーが変更を感じることができません
パッケージは、実際のフォルダである(しかし、そのフォルダ内にこのファイルが含まれている必要があります_ _ _ init_の.py)
* initは、パッケージに通常のフォルダを作ることができるパッケージをインポートのinitをインポートすることです
どのような種類のを使用することです何で私のために一時的なパッケージ(推奨されません)の最初の使用、
* INIT案内パッケージが導入され、
参照などの環境変数の実行可能ファイルのパッケージに、initパッケージは、パッケージ名からインポートを開始することができます
インポートは、相対的及び絶対的、相対パッケージにのみ導入さ導入します
(ポイントは、現在のディレクトリです)
...(現在のディレクトリ(フォルダ)のディレクトリです)
時間モジュール
タイムアクションモジュール:時間の異なる3種類をサポートしている間に、別のフォームが毎回変換することができます
一般的に使用される時間モジュールの使用
import time
# 时间戳
#print(time.time()) #1566008722.4859853
#格式化时间
#print(time.strftime('%Y_%m_%d %X')) #2019_08_17 10:27:44
#结构化时间
#localtime():表示中国时间
#print(time.localtime()) #time.struct_time(tm_year=2019, tm_mon=8, tm_mday=17, tm_hour=10, tm_min=29, tm_sec=8, tm_wday=5, tm_yday=229, tm_isdst=0)
# gmtime()标准时间
#print(time.gmtime()) #time.struct_time(tm_year=2019, tm_mon=8, tm_mday=17, tm_hour=2, tm_min=31, tm_sec=5, tm_wday=5, tm_yday=229, tm_isdst=0)
フォーマット変換時の三種類(覚えておく必要はありません)
キーjは覚えています:
time.time()
time.sleep(2)
datetimeモジュール
datetimeモジュールの効果:修正時刻用
import datetime
print(datetime.datetime.now())
now = datetime.datetime.now()
print(now + datetime.timedelta(3)) #默认+3天
print(now + datetime.timedelta(hours=3)) # +3小时
print(now+ datetime.timedelta(minutes=3)) #+3 分钟
print(now.replace(year=1900))
osモジュール
osモジュールの役割:オペレーティングシステムと対話するために、あなたはファイルを操作することができます
# import os
#print(os.getcwd()) # 获取当前文件目录
#os.mkdir('m3') # 创建文件
#os.rmdir('m3') # 删除文件
###############(重点,经常使用)
# res = os.listdir(r'E:\老男孩')
# print(res) #列出所有的文件
#os.rename('日常学习总结.py','总结.py')#修改文件名
# os.remove('price.txt') #删除文件
# __ file__只有pycharm才提供,python本身不支持
#print('os.path.abspath(__file__):',os.path.abspath(__file__)) # 显示当前文件路径,支持不同平台
#print(__file__)#E:/老男孩/日常使用.py
# print(os.path.exists('bao')) #True 判断文件是否存在
#print(os.path.isfile('bao')) #False 判断是否为文件
#print(os.path.isdir('bao')) #Trun 判断是否为文件夹
###############(经常使用),支持不同平台
# res = os.path.join(r'E:\老男孩') # 拼接文件路径
# res = os.path.join(r'E:\老男孩\ATM工程')# 拼接文件路径
# print(r'E:\老男孩+E:\老男孩\ATM工程')
##########(经常使用)
# print(os.path.abspath(__file__)) #E:\老男孩\日常使用.py 打印当前文件路径
# print(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))#E:\ 打印了上上级目录(
# import os
# g = os.walk(r'E:\老男孩\日常使用.py')
# for i in g:
# print(i)
SYSモジュール
SYSモジュールの効果:通訳のpythonとの相互作用
import sys
#print(sys.path)
#print(sys.argv) # 接收参数(用cmd执行文件时才生效)
print(sys.modules)
JSONモジュール
JSONアクションモジュールは:直列化および非直列化、ジェネリックデータ型は(例えば、Pythonで書かれたプログラム、Javaで書かれたプログラム、および今これらの2つのプログラムが交換するが、異なる構文を認識しない、予め決定することができます多言語の統一されたデータ型、JSON文字列
シリアル化:Pythonの辞書(最も一般的)からは、ダンプを持つJSON文字列になります
fは、デシリアライズ:JSONからPythonの文字列辞書(最も一般的)に、負荷で
import json
# dict = {'a': 1, 'b': 2, 'c': None}
# data = json.dumps(dict) # 序列化到内存中<class 'str'>
# #print(data,type(data)) #{"a": 1, "b": 2, "c": null}单引号变双引号d
# data = json.loads(data)# 从内存获取json串
# print(data,type(data))#{'a': 1, 'b': 2, 'c': None} <class 'dict'>
with open(f'{"text"}.josn','r',encoding='utf-8')as fr:
data = json.load(fr)
print(data) #{'a': 1, 'b': 2, 'c': None}
pickleモジュール
ピクルスモジュール機能:全てのオブジェクト(データの種類)のpythonをシリアルではなく、クロスプラットフォーム(JSONモジュールクロスプラットフォーム)
hashlibモジュール
hashlibモジュールの役割:パスワードの暗号化、関係なく、あなたは文字列を投げる何、それは固定長文字列の文字列を返しません
import hashlib
m = hashlib.md5()
# m.update(b'123456')
# print(m.hexdigest()) #e10adc3949ba59abbe56e057f20f883e
m.update(b'123')
m.update(b'456')
print(m.hexdigest())#e10adc3949ba59abbe56e057f20f883e(有叠加性)
#1.变成固定的字符串、
# 2. 相同的字符串哈希后的结果一样、
# 3. 叠加性
HMACモジュール
HMACモジュール機能:パスワードを暗号化するために、あなたは塩を追加することができます
import hmac
m = hmac.new(b'a')
m.update(b'123456')
print(m.hexdigest())#8c7498982f41b93eb0ce8216b48ba21d
#m = hamc.new(b'abc)#8c7498982f41b93eb0ce8216b48ba21d
#m = hamc.new(b'a) #3e391a1d7bf574cec59679244a2904fe
# 特性:1.不同的hamc,最后打印结果不同
#2.同样具有叠加性
ロギングモジュール
ログインモジュールの役割:ログ
import logging
# logging.debug('调试') # 10
# logging.info('正常') # 20 # 用这一个
# logging.critical('严重错误') # 30
# logging.error('错误') # 40
# logging.warning('警告') # 50
# 默认30以上的可以输出
# v2 日志信息记录在文件当中
# logging.basicConfig(filename='access.log',
# format='%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s',
# datefmt='%Y-%m-%d %H:%M:%S %p',
# level=10)
# logging.debug('调试信息') # 10
# logging.info('正常信息') # 20
# logging.warning('警告信息') # 30
# logging.error('报错信息') # 40
# logging.critical('严重错误信息') # 50
# v3
# 1. 生成一个logger对象
logger = logging.getLogger('nick')
# 2. 生成格式
formmater1 = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s -%(module)s: %(message)s',
datefmt='%Y-%m-%d %H:%M:%S %p',)
formmater2 = logging.Formatter('%(asctime)s : %(message)s',
datefmt='%Y-%m-%d %H:%M:%S %p',)
formmater3 = logging.Formatter('%(name)s %(message)s',)
# 3. 生成一个文件对象
h1 = logging.FileHandler('h1.log')
h2 = logging.FileHandler('h2.log')
sm = logging.StreamHandler()
# 4. 文件绑定格式
h1.setFormatter(formmater1)
h2.setFormatter(formmater2)
sm.setFormatter(formmater3)