模塊 (類庫)

来源:https://www.cnblogs.com/wenxin1120/archive/2019/04/19/10739104.html
-Advertisement-
Play Games

一:模塊的基本認識: 內置模塊是python自帶的功能,在使用內置模塊相應功能時,需要先導入再使用 下載-->安裝-->使用 1.找到python所在的根目錄-->再找到Scripts目錄-->最後找到pip.exe 2.把pip.exe所在的目錄添加到環境變數中 3.pip install 要安裝 ...


一:模塊的基本認識:

  1. 內置模塊
    • 內置模塊是python自帶的功能,在使用內置模塊相應功能時,需要先導入再使用  
  2.  第三方模塊
    • 下載-->安裝-->使用
      1.找到python所在的根目錄-->再找到Scripts目錄-->最後找到pip.exe
      2.把pip.exe所在的目錄添加到環境變數中
      3.pip install 要安裝的模塊名稱   #pip install xlrd
      
      #安裝完成後,如果導入不成功
          - 重啟pycharm
           - 安裝錯了 
  3. 自定義模塊
    • 自己寫一個模塊(一個py文件) : aaa.py
      def f1():
          prinrt('f1')
      def f2():
          print('f2')
    • 在另一個py文件中調用模塊中的功能 :a1.py
      #調自定義模塊中的功能
      import aaa
      aaa.f1()
      aaa.f2() 
    • 運行
      a1.py 

二:模塊的調用

1.示例一:

# xxx.py

def show():
    print('nihao')
def func():
    pass

print(111)
#導入模塊,載入此模塊中的所有值到記憶體(一)
import xxx
print(222)
##調用模塊中的函數
xxx.func()

 

#導入模塊(二)
from xxx import func,show
from xxx import func
from xxx import *
func()

 

#導入模塊(三)
from xxx import func as f  #起別名
def func():
    print(222)
f()

2.示例二:

xxxxxx  #(某個文件夾)
   -jd.py  #裡面有個f1函數
   -tb.py
   -pdd.py
import xxxxxx.jd
jd.f1()
from xxxxxx import jd
jd.f1()

 

from xxxxxx.jd import f1
f1()

 

3.總結

 

模快和要執行的py文件在同一目錄且需要模塊中的很多功能時,推薦使用:import 模塊

 

  • 其他推薦:from 模塊 inport 模塊 模塊.函數()

  • 其他推薦:from 模塊.模塊 import 函數()

三:內置模塊及其使用方法

  • .random

    #獲取6個Unicode對應表中十進位相對應的數據

    import
    random def get_random_code(length = 6): data = [] for i in range(length): v = random.randint(65,90) data.append(chr(v)) return ''.join(data) code = get_random_code() print(code)
    import random # 導入一個模塊
    v = random.randint(起始,終止)  #得到一個隨機數

 

  • .hashlib :用於加密相關的操作,代替了md5模塊和sha模塊

 

  • 將指定的'字元串'進行加密
    import hashlib
    def get_md5(num):
        obj = hashlib.md5()
        obj.update(data.encode(utf-8))
        result = obj.hexdigest()
        return result
    val = get_md5('某段數字')
    print(val)
  • 加鹽 : (讓密碼更加安全)
    import hashlib
    
    def get_md5(data):         # md5括弧內的內容越長,越不容易被破解
        obj = hashlib.md5("sidrsicxwersdfsaersdfsdfresdy54436jgfdsjdxff123ad".encode('utf-8'))
        obj.update(data.encode('utf-8'))
        result = obj.hexdigest()
        return result
    
    val = get_md5('123')
    print(val)
  • sys : python解釋器相關的數據
    • sys.getrefcount : 獲取一個值的應用計數
      import sys  #導入模塊
      a = [1,2,3]
      b = a
      print(sys.getrefcount(a)) 
      #結果為:3   相當於a被使用了三次
    • sys.getrecursionlimit : python中預設支持的遞歸數量
      import sys 
      print(sys.getrecursionlimit())
      # 結果為 :1000
    • sys.argv : 命令行參數,第一個元素是程式本身路徑

      #寫一個腳本,接收兩個參數。

      
      
      • 第一個參數:文件
      • 第二個參數:內容
      
      

      #請將第二個參數中的內容寫入到 文件(第一個參數)中

      import sys
      
      if len(sys.argv) < 3:
          print('參數不夠,請重新運行')
      else:
          file_path = sys.argv[1]
          content = sys.argv[2]
          with open(file_path,mode='w',encoding='utf-8') as f:
              f.write(content) 
    • sys.path : 預設python去導入模塊時,會按照sys.path中的路徑挨個查找
      import sys
      sys.path.append('D:\\')
      import oldboy
  • os : 和操作系統相關的數據
    • os.path.exists(path) , 如果path存在,返回True;如果path不存在,返回False
    • os.stat('某個文件').st_size : 獲取文件大小

    • os.path.abspath() : 獲取一個文件的絕對路徑

      path = '某個需要查看路徑的文件' 
      
      import os
      v1 = os.path.abspath(path)
      print(v1)  # 這個文件所在的全部目錄

       

    • os.path.dirname : 獲取路徑的上級目錄
      import os
      v = r"C:\python36\新建文件夾\python36.exe D:/第三周/day14.py"
      print(os.path.dirname(v))
      
      #C:\python36\新建文件夾\python36.exe D:/第三周   一級一級往上走 
    • os.path.join : 路徑的拼接
      import os
      path = "C:\python36\新建文件夾\python36.exe" 
      v = 'n.txt'
      
      result = os.path.join(path,v)
      print(result)
      #C:\python36\新建文件夾\python36.exe \n.txt
      
      result = os.path.join(path,'n1','n2','n3')
      print(result)
      #C:\python36\新建文件夾\python36.exe \n1\n2\n3
    • os.listdir :查看一個目錄下所有的文件(第一層)
      import os
      result  = os.listdir(r'D:\untitled')
      for i in result:
          print(i)
    • os.walk : 查看一個目錄下所有的文件(所有層)
      import os
      
      result = os.walk(r'D:\untitled')
      for a,b,c in result:
          # a,正在查看的目錄 b,此目錄下的文件夾  c,此目錄下的文件
          for item in c:
              path = os.path.join(a,item)
              print(path)
    •  os.makedirs 創建目錄和子目錄

 

    • os.rename 重命名
      import os
      os.rename('某個文件的名字','想要修改後的名字')
    • os.stat 讀取文件大小
      import os
      #1.讀取文件大小(位元組)
      file_size = os.stat('某個文件').st_size
      #2. 一點一點讀取文件
      read_size = 0
      with open('某個文件',mode='rb') as f1,open('將要寫入的文件',mode='wb') as f2:
          while read_size < file_size:
              chunk = f1.read(1024) #每次最多去讀取1024位元組
              f2.write(chunk)
              read_size += len(chunk)
              val = int(read_size / file_size * 100)   #查看列印進度
              print('%s%%\r' %val ,end='')
  • json&pickle

    • json : 一個特殊的字元串 [長得像列表/字典/字元串/數字/真假]

      • 優點:所有語言通用;缺點:只能序列化基本的數據類型

      • json.dumps 序列化

      • json.loads 反序列化

    • pickle:優點:python中所有的東西都能被他序列化 缺點:序列化的內容只有python認識
      import json
      #序列化:將python的值轉換為json格式的字元串
      v = [11,22,{'k1':'v1'},True,'ggg']
      v1 = json.dumps(v)
      print(v1)    #"[11, 22, {"k1": "v1"}, true, "ggg"]"
      
      #反序列化 : 將json格式的字元串轉換成python的數據類型
      v2 = '["alex",123]'
      print(type(v2))  #字元串類型
      v3 = json.loads(v2)
      print(v3,type(v3))   #['alex', 123] <class 'list'>
    • 字典或列表中如有中文,序列化時想要保留中文顯示
      v = {'k1':'alex','k2':'李傑'}
      
      import json
      val = json.dumps(v,ensure_ascii=False)
      print(val)

 

    • 註意:

      • json 最外層必須是容器類的,如列表/字典,元組會被轉換為列表.

      • 裡面的內容可以是:str int bool list tuple 集合不能存在於json中

      • 字串必須使用雙引號(" ")連接

 

 

  • shutil

    • 刪除目錄

      import shutil
      shutil.rmtree('要刪除的目錄')

       

       

    •  重命名
      import shutil
      shutil.move('原目錄','修改後的目錄')

       

    •  壓縮文件 shutil.make_archive
      import shutil
      shutil.make_archive('要壓縮的文件','文件的尾碼名(如zip)','要壓縮到的路徑')

       

    •  解壓文件 shutil.unpack_archive
      import shutil
      shutil.unpack_archive('要解壓的文件',extract_dir=r'D:\code\xxxxxx\xxxx',format='zip')

       

  • time&datetime

    • UTG/GMT 世界時間

    • 本地時間 本地時區的時間

    • time :

      1. time.time() 時間戳(獲取當前時間) 從1970-1-1 00:00 後走過的秒數

      2. time.sleep(8) 等待的秒數

    •  獲取datetime格式時間
      import time
      from datetime import datetime,timezone,timedelta
      
      v1 = datetime.now()  # 獲取當前本地時間
      print(v1)            # 2019-04-18 16:39:31.802269
      
      tz = timezone(timedelta(hours=7)) #當前東7區時間  (如要獲取西7區時間 hours=-7)
      v2 = datetime.now(tz)
      print(v2)         #2019-04-18 15:39:31.802269+07:00   (中國在東8區,所以慢一個小時)
      
      v3 = datetime.utcnow()    #當前UTC時間(世界時間)
      print(v3)                 #2019-04-18 08:39:31.802269  (比中國時間慢8個小時)

       

    •  把datetime格式轉換成字元串 (strftime)
      import time
      from datetime import datetime,timezone,timedelta
      
      v1 = datetime.now()
      val = v1.strftime("%Y-%m-%d %H:%M:%S")  #(年-月-日 時:分:秒)
      print(val)    #2019-04-18 16:48:29

       

    •  字元串轉成datetime格式 datetime.strptime
      import time
      from datetime import datetime,timezone,timedelta
      
      v1 = datetime.strptime('2019-4-18','%Y-%m-%d')
      print(v1,type(v1))  # 2019-04-18 00:00:00 <class 'datetime.datetime'>

       

    •  datetime時間的加減
      import time
      from datetime import datetime,timezone,timedelta
      
      v1 = datetime.strptime('2008-08-08','%Y-%m-d')   
      v2 = v1-timedelta(days=150)   #括弧里的內容可以是:(year+或-  month+或-)
      data = v2.strftime('%Y-%m-%d')
      print(data)  #2008-03-11
      
      #先轉換為datetime格式進行加減,然後轉換為字元串格式列印出來

       

    •  時間戳和datetime的關係
      import time
      from datetime import datetime,timezone,timedelta
      
      ctime = time.time()
      print(ctime)  # 1555578896.8276453
      v1 = datetime.fromtimestamp(ctime)
      print(v1) # 2019-04-18 17:14:56.827645
      
      v1 = datetime.now()
      val = v1.timestamp()
      print(val)  #1555579030.002739

       

 四:異常處理

#固定搭配

 try:


 except Exception as e:
#寫函數去,接受一個列表。列表中都是url,請訪問每個地址並獲取結果。
import requests 
def func(url_list):
    result = []
    try:
        for url in url_list:
            response = requests.get(url)
            result.append(response.text)
    except Exception as e:
        pass
    return result    #['http://www.baidu.com']  (中國無法訪問谷歌)

def func2(url_list):
    result = []
    for url in url_list:
        try:
            response = requests.get(url)
            result.append(response.text)
        except Exception as e:
            pass
    return result   #['http://www.baidu.com','http://www.bing.com']

func(['http://www.baidu.com','http://www.google.com','http://www.bing.com']) 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原創不易,如需轉載,請註明出處 "https://www.cnblogs.com/baixianlong/p/10739579.html" ,希望大家多多支持!!! 一、線程基礎 1、線程與進程 線程是指進程中的一個執行流程,一個進程中可以運行多個線程。 進程是指一個記憶體中運行的應用程式,每個進程都 ...
  • 項目文件 01_QtTest.pro 頭文件 mywidget.h 源文件 main.cpp mywidget.cpp 結果顯示 ...
  • 這是最後一條NLP了......來吧 十二,動機和情緒總不會錯,只是行為沒有效果而已 動機在潛意識裡,總是正面的。潛意識從來不會傷害自己,只會誤會的以為某行為可以滿足該動機,而又不知道有其他做法的可能。 情緒總是給我們一份推動力,情緒使我們在該事情之中有所學習,學到了,情緒便會消失。 我們可以接受一 ...
  • 一.Spring概述 Spring是一個JavaEE輕量級的一站式 Java EE的開發框架。 1. Spring是一個一站式的企業級(JavaEE)開發框架,意味著,僅僅使用一個Spring框架就可以滿足JavaEE開發的表示層,服務層,持久層的開發。 2. Spring強調的理念是,輕量級。意味 ...
  • 一、spring簡介 Spring是一個JavaEE輕量級的一站式的開發框架(spring的可插拔特性,企業用於整合其他框架)輕量級:使用最少的代碼啟動程式,根據所需選擇功能選擇模塊使用一站式:提供了表示層,服務層,持久層的所有支持(功能齊全) 二、spring框架的優點 優秀的架構標準: 1.可維 ...
  • [TOC] 開始編寫球隊代碼 裝好了Robocup 3D比賽平臺後,就要開始著手編寫球隊策略代碼了。 我們使用的是utaustinvilla的Robocup 3D球隊代碼,球隊的體態運動等都已經是別人寫好的,我們暫時不要研究。 在下圖中,behaviors文件夾下的strategy.cc文件,就是我 ...
  • 同源策略 如果兩個頁面的協議,埠(如果有指定)和功能變數名稱都相同,則兩個頁面具有相同的源。 示例:兩個Django demo demo1 url.py view.py demo2 url.py view.py demo.html <body> <button id="btn">點擊</button> < ...
  • 一:三元計算(三目計算) 二:函數的基本認識 1.函數式編程: - 本質:將N行代碼拿到別處並給他起個別名,以後通過名字就可以找到這行代碼並執行 - 場景:1.代碼重覆執行 2.代碼量特別多超過一屏,可以通過函數進行代碼的分割 2.函數的基本結構 3.函數參數: 定義一個函數:給了函數一個名稱,指定 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...