模塊
三種方法:
- 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該字串就為原始字串,所有的轉義字符都無效
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/508074.html
標籤:其他
