模塊 三種方法: import from 模塊 import 成員,成員 from 模塊 import * *代表所有的成員 隱藏成員: 模塊中以下劃線_開頭的屬性 隱藏成員不會被from 模塊 import * 導入 導入模塊時會將模塊的代碼全部執行 as 取別名 from module01 im ...
模塊
三種方法:
- import
- from 模塊 import 成員,成員
- from 模塊 import * *代表所有的成員
隱藏成員: 模塊中以下劃線_開頭的屬性
隱藏成員不會被from 模塊 import * 導入
導入模塊時會將模塊的代碼全部執行
as 取別名
from module01 import f as f1
模塊變數
__file__ : 模塊對應的文件路徑名,返回的是一個絕對路徑
絕對路徑:從盤符開始一層一層
__name__ : 模塊自身的名字
如果在當前模塊運行,則名字為__main__,否則為模塊真名
# 只需要一次模塊當作程式運行的代碼
if __name__ = '__main__'
print("主模塊 ")
模塊分類
-
內置模塊 : builtins.py
-
用戶自己編寫的模塊
-
標準庫
-
第三方模塊
第三方模塊開源: pip install 模塊名 pip install 模塊名 -i 源地址 PIP國內源: 1)清化大學 PIP源地址:https://pypi.tuna.tsinghua.edu.cn/simple 2)阿裡雲 PIP源地址:http://mirrors.aliyun.com/pypi/simple/ 3)豆瓣 PIP源地址:http://pypi.douban.com/simple/ 4)中國科學技術大學 PIP源地址:http://pypi.mirrors.ustc.edu.cn/simple/ 5)華中科技大學 PIP源地址:http://pypi.hustunique.com/
常用模塊
sys
sys = system簡寫 系統的意思
sys.modules # 獲得導入的所有模塊,結果是本字典
sys.path # 搜索路徑,結果是個列表
sys.platform # 獲得操作系統
os
系統交互模式 = cmd
os.system() # 執行cmd命令,命令用字元串表示
os.getcwd() # 獲得工作路徑,項目文件的路徑
os.mkdir() # 創建文件夾
os.rmdir() # 刪除文件夾(只能刪除空文件夾)
os.remove() # 刪除文件
os.rename() # 文件重命名(原名字,新名字)
os.chdir() # 切換文件夾
os.listdir() # 獲得指定目錄下所有文件的目錄名
# 重要
os.path.exists(path) # 判斷文件或者文件夾是否存在
os.path.isfile(path) # 判斷是否為文件
os.path.isdir(path) # 判斷是否為文件夾
time
import time
time.time() # 返回一個時間戳 從1970年到現在經過多少秒
time.sleep() # 程式休眠(int)
time.strftime("時間格式",時間對象)
# %Y 年 year
# %m 月 month
# %d 日 day
# %H 時 hour
# %M 分 minute
# %S 秒 second
月跟日是小寫 其餘全部大寫
print(time.strftime("%Y %m %d %H:%M:%S", t))
random
random.random() # 生成一個打鬱0,小於1的隨機小數
random.randint(start,end) # 生成一個隨機範圍的整數(包括開頭結尾)
random.uniform(start,end) # 生成一個隨機範圍的小數
random.choice(序列) # 從序列中隨機提取一個元素
random.choices(序列,k=數量) # 從序列中隨機提取多個元素(抽出一個再放回再抽)
random.suffle(序列) # 將原序列打亂(必須是可變序列)
json
json 其實是一種文件的存儲格式
json相容性很強,網路上大部分數據都是以json形式傳遞讓每種語言都可以靈活訪問。 跨平臺,跨語言
json.loads # json轉python
json.dupms # python轉json
json.load # 從文件中json轉python
json.dupm # python轉json到文件中
re
正則表達式:普通字元和元字元構成的字元串,描述一類字元串規則
re.match("正則","匹配的字元串") # 匹配到了就返回,匹配不到就返回None
re.findall("正則","匹配的字元串") # 把能匹配到的都放到列表裡面去
re.match("")
元字元:
. 除了\n的任意一個字元
\d 數字
\D 非數字
\s 空白 # [\n \t 空格]
\S 非空白
\w 數字,字母,下劃線
\W 非數字,字母,下劃線
字元集:使用中括弧來表示,表示一個字元範圍,字元集也是一個字元
res = re.match("[abzs]","zbasdf")
# <_sre.SRE_Match object; span=(0, 1), match='z'>
字元集中可以使用 - 表示一個範圍
[0-9],[a-z],[A-Z][A-Za-Z]
取反: ^
res = re.match("[^a-e]", 'z')
數量規則:
* 匹配前一個字元的任意次數(可以是0次)
res = re.match("\d*", 'w') # 0次,如果不加*則匹配None
# <_sre.SRE_Match object; span=(0, 0), match=''>
res = re.match("\w*", 'www111') # 匹配多次,知道匹配不到
# <_sre.SRE_Match object; span=(0, 15), match='www'>
+ 匹配一個字元的1次及1次以上
? 匹配前一個字元0次或者1次
{a} # 只能匹配a個
{a,} # 至少匹配a個
{a,b} # 至少匹配a,至多匹配b個
邊界處理:
開始:^ 在外面這個叫做邊界
結尾:$
固定數量:
res = re.match("^w{3}$", 'wwww') # None
原始字元串
在字元串前面家上r該字元串就為原始字元串,所有的轉義字元都無效