菜鳥的Python學習筆記_源碼閱讀1_records(part1)

来源:https://www.cnblogs.com/rookieshome/archive/2023/09/22/17721402.html
-Advertisement-
Play Games

records 使用原生sql,可以操作大多數的關係型資料庫 PART_1 - records引入的包(部分) 1. from sys import stdout 說明:標準輸出流 具體請參考:(https://pythonjishu.com/python-sys-stdout/)[https:// ...


records---使用原生sql,可以操作大多數的關係型資料庫


PART_1 - records引入的包(部分)


1. from sys import stdout


2. os.environ


3. from collections import OrderedDict

作用:collections模塊是用於提供一些高級數據結構,用於處理各種類型的集合。這些數據結構有助於提高代碼的可讀性和可維護性,同時也可以用於實現一些常用的演算法。
主要內容:

  • Counter:一個簡單的計數器,用於統計一個字典中各個鍵出現的次數。
  • defaultdict:一個字典的副本,當對字典中的某個鍵進行操作時,如果鍵不存在,則創建一個新的鍵值對。
  • deque:一個雙端隊列,用於實現隊列和堆棧的功能。
  • OrderedDict:一個有序字典,用於保存字典中的鍵值對,且其中的鍵值對按照插入順序進行排序。
  • ChainMap:一個鏈式字典,用於合併多個字典,使得對其中任何一個鍵的訪問都返回對應的值。
  • Counter和OrderedDict都實現了__missing__方法,當對不存在於字典中的鍵進行操作時,會返回一個預設值。
  • namedtuple:一個創建具有命名的欄位和預設值的元組的工具。
  • UserDict:一個抽象基類,用於實現一個簡單的字典。
  • UserList:一個抽象基類,用於實現一個簡單的列表。
  • Itertools:一個包含各種迭代工具的模塊,例如無限迭代器、組合迭代器等。

4. from contextlib import contextmanager

  • 作用:contextlib模塊提供了一個用於生成上下文管理器的工具。上下文管理器是一種用於自動處理資源分配和釋放的聲明式編程方式。在Python中,上下文管理器是一種用於處理資源分配和釋放的聲明式編程方式。它們通常用於with語句中,確保在with語句塊結束時,資源被正確釋放。
  • 主要內容:
  • contextlib.contextmanager(): 這是一個裝飾器,用於將一個生成器函數轉換為上下文管理器。
  • contextlib.closing(): 這是一個上下文管理器,用於自動關閉一個資源。
  • contextlib.suppress(): 這是一個上下文管理器,用於捕獲並忽略一個異常。

5. from inspect import isclass

  • 作用:inspect模塊用於檢查Python代碼的對象,如模塊、類、方法、函數等。它可以幫助你獲取模塊、類的屬性和方法、函數的參數等信息。
  • 主要內容:
  • inspect.getmodule(): 這是一個函數,用於獲取一個模塊對象。
  • inspect.getmembers(): 這是一個函數,用於獲取一個模塊中所有成員的名稱和對象。
  • inspect.ismodule(): 這是一個函數,用於檢查一個對象是否為模塊。
  • inspect.isclass(): 這是一個函數,用於檢查一個對象是否為類。
  • inspect.ismethod(): 這是一個函數,用於檢查一個對象是否為方法。
  • inspect.isfunction(): 這是一個函數,用於檢查一個對象是否為函數。
  • inspect.signature(): 這是一個函數,用於獲取一個函數的簽名。
#示例:
import inspect

def my_function(a, b, c):
  pass

# 獲取一個函數的簽名
signature = inspect.signature(my_function)
print(signature)

# 獲取一個模塊中所有成員的名稱和對象
members = inspect.getmembers(inspect)
for name, obj in members:
    print(f"{name}: {obj}")

6. import tablib

  • 作用:tablib模塊是一個用於處理表格數據的庫。它提供了多種數據格式,如CSV、JSON、XLSX等,以及用於創建、操作和格式化表格數據的類。tablib模塊可以幫助你輕鬆地處理各種表格數據操作,如合併表格、排序表格等。
  • 主要內容:
  • tablib.Dataset(): 這是一個用於創建和操作表格數據的類。
  • tablib.Table(): 這是一個用於創建和操作表格數據的類。
  • tablib.Format(): 這是一個用於定義數據格式的類。
  • tablib.Package(): 這是一個用於將多個數據格式組合成一個包的類。
#示例:
from tablib import Dataset

data = [
   ['Name', 'Age', 'City'],
   ['Alice', 30, 'New York'],
   ['Bob', 25, 'San Francisco'],
   ['Charlie', 22, 'Los Angeles']
]

dataset = Dataset(*data)

# 將表格數據寫入CSV文件
with open('output.csv', 'wb') as f:
   f.write(dataset.export('csv'))

# 將表格數據寫入XLSX文件
with open('output.xlsx', 'wb') as f:
   f.write(dataset.export('xlsx'))  

7. from docopt import docopt

  • 作用:docopt模塊是一個用於解析命令行參數的庫。它可以幫助你根據命令行參數的定義來生成相應的幫助文檔和處理命令行參數。docopt模塊基於命令行參數的名稱來生成相應的幫助文檔,使得用戶能夠通過命令行參數來指定配置文件、操作等。
  • 主要內容:
  • docopt.docopt(): 這是一個用於解析命令行參數的函數。它接受一個參數,即命令行參數的定義,返回一個包含解析結果的字典。
  • docopt.DocoptExit(): 這是一個異常類,用於在解析命令行參數時出現錯誤時拋出。
  • Ps: docopt源碼也適合作為閱讀的對象

8. from sqlalchemy import create_engine,exc,inspect,text

  • 作用:sqlalchemy模塊是一個用於處理SQL查詢的庫。它提供了一個高級的ORM(對象關係映射)以及一個底層的SQL表達式語言。sqlalchemy模塊可以幫助你輕鬆地執行資料庫操作,如查詢、插入、更新和刪除等。
  • 主要內容:
  • sqlalchemy.create_engine(): 這是一個函數,用於創建一個資料庫引擎。
  • sqlalchemy.Column(): 這是一個類,用於定義資料庫表的列。
  • sqlalchemy.Integer(): 這是一個類,用於表示整數類型。
  • sqlalchemy.String(): 這是一個類,用於表示字元串類型。
  • sqlalchemy.MetaData(): 這是一個類,用於定義資料庫表的元數據。
  • sqlalchemy.Table(): 這是一個類,用於定義資料庫表。
  • sqlalchemy.select(): 這是一個類,用於構建SQL查詢。
#示例:
from sqlalchemy import create_engine, Column, Integer, String, MetaData, Table, select

# 定義一個資料庫引擎
engine = create_engine('sqlite:///example.db')

# 定義一個資料庫表
metadata = MetaData()
users = Table('users', metadata,
             Column('id', Integer, primary_key=True),
             Column('name', String),
             Column('age', Integer))

# 創建表
metadata.create_all(engine)

# 插入一條數據
ins = users.insert().values(name='Alice', age=30)
conn = engine.connect()
conn.execute(ins)

# 執行一個查詢
s = select([users])
result = conn.execute(s)
rows = result.fetchall()

# 列印查詢結果
for row in rows:
 print(row)

# 關閉連接
conn.close()


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

-Advertisement-
Play Games
更多相關文章
  • 對於iOS開發者而言,CocoaPods並不陌生,通過pod相關的命令操作,就可以很方便的將項目中用到的三方依賴庫資源集成到項目環境中,大大的提升了開發的效率。CocoaPods作為iOS項目的包管理工具,它在命令行背後做了什麼操作?而又是通過什麼樣的方式將命令指令聲明出來供我們使用的?這些實現的背... ...
  • 這裡給大家分享我在實際生活中總結出來的一些知識,希望對大家有所幫助 一.SDK引入 這裡提供兩套引入流程,一套是vue2.0及其他h5項目,一套是vue3.0的引入流程 不懂的也可以看我之前的一篇詳細流程 記錄--微信調用jssdk全流程詳解 1.js引入 直接在你的頁面里引入js文件就行 <scr ...
  • 上半年vercel 推出了nextjs13 這個大版本,剛好最近有個c端的項目,所以就用了這個框架來寫,技術體系基本也是文檔提到的 tailwindcss + ts + swr + ssr ,總的來開發體驗還可以,不管是打包速度、文檔、錯誤信息提示目前都還滿意,只不過目前nextjs13 中文資料有 ...
  • 在JavaScript開發的現代世界中,有許多不同的前端框架可供我們用來編寫應用程式,從舊的框架如Backbone.js到較新的Angular、React和Vue等。這些框架通常使用模型視圖控制器(MVC)設計模式或其變體之一,例如模型視圖表現器(MVP)或模型視圖視圖模型(MVVM)。當將這組模式 ...
  • 本文是由最近做的一個項目有感而發,因為之前做了一些技術棧的統一,為了用ant Design的pro-table,PC統一使用react,但是我們有一些老的項目是vue的,本次新頁面較多,老頁面的改動較少,除此之外老項目想換菜單,因此我們想藉助本次機會用react開發,經過了幾番思考,發現本次很適合用... ...
  • web前端JavaScript交互 點擊事件 意義: JavaScript中的點擊事件是指當用戶在頁面上點擊某個元素時觸發的事件。這個事件可以用於執行各種操作,如改變元素的樣式、修改頁面內容等。這是Web應用程式中最常用 的交互方式之一,允許用戶與網頁進行交互,提高用戶體驗。 案例: 隨機點名器 知 ...
  • import React, { useEffect, useState } from 'react'; hook 是react 16.8的新增特性 ,他可以讓你不在編寫class的情況下shiystate以及react的特性 Hooks的出現,首先解決了以下問題: 告別了令人疑惑的生命周期 告別類組 ...
  • 不同行業基本都會有自己獨特的業務,甚至同行的不同企業之間的業務邏輯也會相差千里,只有最大程度抽象出通用性、標準性和普適性的系統才能夠成為平臺系統,平臺系統開發的成本和難度可想而知。 個人深度參與或獨立設計開發過的公共服務型平臺系統,主要包括基礎數據平臺、支付平臺、財務平臺、結算平臺、配送平臺、CRM ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...