1. 程式人生 > >python--內建模組(02)

python--內建模組(02)

1.os模組

os模組主要針對作業系統,一般用來操作檔案系統

os.makedirs()可以一次性建立多級目錄

os.rmdir()刪除一個資料夾

os.path.dirname() 獲取到檔案的資料夾

 

import os

必須要記住.很常用
os.makedirs("baby/安哥拉/特斯拉/黃曉明") # 可以一次性建立多級目錄

os.mkdir("hyf\zxx\lvb") # 上層資料夾必須存在


os.removedirs("baby/安哥拉/特斯拉/黃曉明") # 可以幫我們刪除當前這個目錄級中的所有空資料夾
需要記住
os.rmdir("baby/baobao/baby/黃曉明") # 指定資料夾刪除

os.system("dir")
print(os.popen("dir").read()) # 執行shell指令碼或者cmd命令

print(os.getcwd()) #  當前程式執行的資料夾  D:\python_workspace_s18\day23 內建模組02

os.chdir("baby") # 改變工作目錄

print(os.getcwd())
f = open("../userinfo", mode="r", encoding="utf-8")
for line in f:
    print(line)


os.path 和路徑相關的內容
print(os.path.abspath('userinfo') ) # 把相對路徑改成絕對路徑
print(os.path.split(r"D:\python_workspace_s18\day23 內建模組02\userinfo"))

print(os.path.dirname(r"D:\python_workspace_s18\day23 內建模組02\userinfo"))
print(os.path.basename(r"D:\python_workspace_s18\day23 內建模組02\userinfo"))

print(os.path.exists(r"D:\python_workspace_s18\day23 內建模組02") ) # 存在?


exit()


  

2. sys 

主要針對的是python直譯器

sys.path 模組的查詢路徑

 

import sys
# print(sys.platform)
print(sys.path)  # 找模組的. 必須要記住. 模組的搜尋路徑
sys.path.append("D:\\python_workspace_s18\\day21 繼承")
import master
master.chi()

  

3.序列化

序列化就是把一個物件拍散,把拍散的內容再整合成物件,就叫做反序列化

 

 

4. pickle

把一個物件進行序列化操作

1.dumps() 把物件序列化成位元組

2.loads() 把位元組反序列化成物件

3.dump()把物件序列化寫入檔案

4.load() 把檔案中的內容反序列化成物件

 

e = Elephant("寶寶", "185T", "175")
e.tiaoxi()

# 序列化
bs = pickle.dumps(e) # 把物件進行序列化
print(bs)

bs = b'\x80\x03c__main__\nElephant\nq\x00)\x81q\x01}q\x02(X\x04\x00\x00\x00nameq\x03X\x06\x00\x00\x00\xe5\xae\x9d\xe5\xae\x9dq\x04X\x06\x00\x00\x00weightq\x05X\x04\x00\x00\x00185Tq\x06X\x06\x00\x00\x00heightq\x07X\x03\x00\x00\x00175q\x08ub.'
# 發序列化
dx = pickle.loads(bs) # 發序列化. 得到的是大象
dx.tiaoxi()


e1 = Elephant("寶寶", "185T", "175")
e2 = Elephant("寶貝", "120T", "120")
f = open("大象", mode="wb")
# 這也是序列化
pickle.dump(e1, f) # 沒有s的這個方法是把物件打散寫入到檔案, 序列化的內容不是給人看的
pickle.dump(e2, f) # 沒有s的這個方法是把物件打散寫入到檔案, 序列化的內容不是給人看的

f = open("大象", mode="rb")
while 1:
    try:
        obj = pickle.load(f)
        obj.tiaoxi()
    except Exception:
        break



e1 = Elephant("寶寶", "185T", "175")
e2 = Elephant("寶貝", "120T", "120")

lst = [e1, e2]

pickle.dump(lst, open("大象", mode="wb"))


讀
lst = pickle.load(open("大象", mode="rb"))
for dx in lst:
    dx.tiaoxi()

  

5.json

有些類似與python中的字典,但是有一點不一樣的地方是

在python中, 布林值和空表示為 True,False,None

而在json中,表示為true, false, null

1.dumps() 把物件序列化成位元組

2.loads() 把位元組反序列化成物件

3.dump()把物件序列化寫入檔案

4.load() 把檔案中的內容反序列化成物件

 

import json

dic = {"baby":None, "hxm":False, "syy":"史楊楊"}

s = json.dumps(dic, ensure_ascii=False) # json處理中文的問題
print(s)

d = json.loads('{"baby": null, "hxm": false, "syy": "史楊楊"}')
print(d['baby'])

f = open("baby.json", mode="w", encoding="utf-8")
json.dump({"baby":None, "hxm":False, "syy":"史楊楊"}, f, ensure_ascii=False)

f = open("baby.json", mode="r", encoding="utf-8")
obj = json.load(f)
print(obj)