菜鳥的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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...