欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python3中數(shù)據(jù)校驗(yàn)機(jī)制詳解

 更新時(shí)間:2024年04月24日 11:47:59   作者:rs勿忘初心  
在日常編碼環(huán)節(jié),很大比例的錯(cuò)誤處理工作和參數(shù)的輸入有關(guān),所以這篇文章主要來和大家介紹一下Python3中的數(shù)據(jù)校驗(yàn)機(jī)制,感興趣的可以了解下

在日常編碼環(huán)節(jié),很大比例的錯(cuò)誤處理工作和參數(shù)的輸入有關(guān)。當(dāng)程序里的某些數(shù)據(jù)直接來自用戶輸入時(shí),必須先校驗(yàn)這些輸入值,再進(jìn)行之后的處理,否則就會(huì)出現(xiàn)難以預(yù)料的錯(cuò)誤。

需求

寫一個(gè)命令行小程序,它要求用戶輸入一個(gè) 0~100 范圍的數(shù)字。假如用戶輸入的內(nèi)容無效,就要求其重新輸入。

常規(guī)方案

示例代碼如下:

def input_a_number():
    """要求用戶輸入一個(gè) 0~100 的數(shù)字,如果無效則重新輸入"""
    while True:
        number = input('Please input a number (0-100): ')
        
        if not number:
            print('Input can not be empty!')
            continue
        if not number.isdigit():
            print('Your input is not a valid number!')
            continue
        if not (0 <= int(number) <= 100):
            print('Please input a number between 0 and 100!')
            continue
 
        number = int(number)
        break
 
    print(f'Your number is {number}')

測(cè)試結(jié)果:

Please input a number (0-100):
Input can not be empty!
Please input a number (0-100): hello
Your input is not a valid number!
Please input a number (0-100): 80
Your number is 80

這個(gè)雖然可以滿足我們的需求,但是如果需要校驗(yàn)的輸入有很多,那這個(gè)檢驗(yàn)邏輯就會(huì)很復(fù)雜冗余。

使用pydantic專業(yè)數(shù)據(jù)校驗(yàn)?zāi)K

來看下介紹:

Pydantic 是一個(gè) Python 的數(shù)據(jù)驗(yàn)證庫,它可以讓你定義數(shù)據(jù)模型并自動(dòng)驗(yàn)證輸入數(shù)據(jù)的類型和結(jié)構(gòu)。它的主要目標(biāo)是使數(shù)據(jù)驗(yàn)證變得簡(jiǎn)單、快速和可靠。

以下是 Pydantic 的一些主要功能和優(yōu)點(diǎn):

  • 聲明式模型定義:使用 Pydantic,你可以通過簡(jiǎn)單的 Python 類來定義數(shù)據(jù)模型。這些類使用類型提示來定義字段的類型,并且支持各種 Python 原生類型、自定義類以及第三方庫的類型。
  • 自動(dòng)驗(yàn)證:定義好數(shù)據(jù)模型后,Pydantic 將自動(dòng)驗(yàn)證輸入數(shù)據(jù)的類型和結(jié)構(gòu)是否符合模型的要求。如果數(shù)據(jù)不符合模型定義,Pydantic 將會(huì)引發(fā)驗(yàn)證錯(cuò)誤。
  • 數(shù)據(jù)解析:Pydantic 提供了方便的方法來解析原始數(shù)據(jù)(如 JSON、字典等)并將其轉(zhuǎn)換為定義的數(shù)據(jù)模型實(shí)例。
  • 序列化輸出:除了解析輸入數(shù)據(jù),Pydantic 還可以將數(shù)據(jù)模型實(shí)例序列化為 JSON 字符串或字典等格式,以便于輸出或傳輸。
  • 數(shù)據(jù)轉(zhuǎn)換:Pydantic 允許你定義字段的轉(zhuǎn)換函數(shù),以在數(shù)據(jù)驗(yàn)證或解析過程中對(duì)字段進(jìn)行轉(zhuǎn)換或預(yù)處理。
  • 內(nèi)置驗(yàn)證器:Pydantic 提供了許多內(nèi)置的驗(yàn)證器,如 EmailValidator、LengthValidator 等,用于驗(yàn)證字段的特定屬性。
  • 與 FastAPI 集成:Pydantic 與 FastAPI 框架深度集成,可以直接將 Pydantic 模型用作 FastAPI 路徑操作的請(qǐng)求和響應(yīng)模型。

總的來說,Pydantic 是一個(gè)功能強(qiáng)大且易于使用的數(shù)據(jù)驗(yàn)證庫,特別適用于構(gòu)建需要處理大量數(shù)據(jù)輸入和輸出的 Python 應(yīng)用程序,如 Web 服務(wù)、API 和數(shù)據(jù)處理工具。

上面的需求,重新實(shí)現(xiàn)一次: 

from pydantic import BaseModel, conint, ValidationError
class NumberInput(BaseModel):
    # 使用類型注解 conint 定義 number 屬性的取值范圍
    number: conint(ge=0, le=100)
 
 
def input_a_number_with_pydantic():
    while True:
        number = input('Please input a number (0-100): ')
 
        # 實(shí)例化為 pydantic 模型,捕獲校驗(yàn)錯(cuò)誤異常
        try:
            number_input = NumberInput(number=number)
        except ValidationError as e:
            print(e)
            continue
 
        number = number_input.number
        break
 
    print(f'Your number is {number}')

其它場(chǎng)景

在編寫代碼時(shí),應(yīng)當(dāng)盡量避免手動(dòng)校驗(yàn)任何數(shù)據(jù)(一般搜下都會(huì)有專門的模塊)。因?yàn)閿?shù)據(jù)校驗(yàn)任務(wù)獨(dú)立性很強(qiáng),所以應(yīng)該引入合適的第三方校驗(yàn)?zāi)K(或者自己實(shí)現(xiàn)),讓它們來處理這部分專業(yè)工作。

比如你在開發(fā) Web 應(yīng)用,數(shù)據(jù)校驗(yàn)工作通常來說比較容易。比如 Django 框架就有自己的表單驗(yàn)證模塊,F(xiàn)lask 也可以使用 WTForms 模塊來進(jìn)行數(shù)據(jù)校驗(yàn)。

WTForms模塊介紹:

WTForms 是一個(gè) Python 的 Web 表單驗(yàn)證和渲染庫,用于處理 Web 應(yīng)用程序中的表單。它提供了一個(gè)簡(jiǎn)單而靈活的方式來定義表單,驗(yàn)證用戶輸入并生成 HTML 表單字段。

一個(gè)簡(jiǎn)單而靈活的方式來定義表單,驗(yàn)證用戶輸入并生成 HTML 表單字段。

以下是 WTForms 的一些主要特點(diǎn)和優(yōu)點(diǎn):

  • 簡(jiǎn)單易用:WTForms 提供了一個(gè)簡(jiǎn)潔的 API,使得定義和處理表單變得簡(jiǎn)單和直觀。
  • 表單驗(yàn)證:WTForms 允許你定義表單字段以及它們的驗(yàn)證規(guī)則,例如必填、長度限制、數(shù)據(jù)類型等。當(dāng)用戶提交表單時(shí),WTForms 會(huì)自動(dòng)驗(yàn)證用戶輸入是否符合定義的規(guī)則,并返回相應(yīng)的錯(cuò)誤消息。
  • CSRF 保護(hù):WTForms 內(nèi)置了 CSRF(Cross-Site Request Forgery)保護(hù),可以幫助你防止 CSRF 攻擊。
  • 支持多種字段類型:WTForms 支持多種常見的 HTML 表單字段類型,如文本框、密碼框、復(fù)選框、下拉框等,同時(shí)也支持自定義字段類型。
  • 表單渲染:WTForms 可以根據(jù)表單定義自動(dòng)生成 HTML 表單字段,簡(jiǎn)化了前端開發(fā)的工作。
  • 與 Flask 和 Django 集成:WTForms 可以與 Flask 和 Django 等流行的 Web 框架無縫集成,方便在這些框架中使用。

下面是一個(gè)簡(jiǎn)單的示例,演示如何使用 WTForms 在 Flask 中創(chuàng)建一個(gè)簡(jiǎn)單的登錄表單:

from flask import Flask, render_template, request
from wtforms import Form, StringField, PasswordField, validators
 
# 創(chuàng)建 Flask 應(yīng)用程序
app = Flask(__name__)
 
# 定義登錄表單
class LoginForm(Form):
    username = StringField('Username', [validators.Length(min=4, max=25)])
    password = PasswordField('Password', [validators.DataRequired()])
 
# 定義登錄路由
@app.route('/login', methods=['GET', 'POST'])
def login():
    # 創(chuàng)建登錄表單實(shí)例
    form = LoginForm(request.form)
    # 檢查表單是否已提交且通過驗(yàn)證
    if request.method == 'POST' and form.validate():
        # 獲取表單中的用戶名和密碼
        username = form.username.data
        password = form.password.data
        # 在這里可以進(jìn)行用戶認(rèn)證等操作
        return f'Welcome, {username}!'
    # 渲染登錄頁面并傳入表單實(shí)例
    return render_template('login.html', form=form)
 
if __name__ == '__main__':
    app.run(debug=True)

在上面的示例中,我們首先定義了一個(gè)名為 LoginForm 的表單類,其中包含了用戶名和密碼兩個(gè)字段,并指定了它們的驗(yàn)證規(guī)則。然后,我們?cè)诘卿浡酚芍惺褂迷摫韱晤悇?chuàng)建了表單實(shí)例,并在提交表單時(shí)進(jìn)行了驗(yàn)證。如果表單驗(yàn)證通過,就可以獲取用戶名和密碼并進(jìn)行相應(yīng)的處理。

當(dāng)然,你需要在 Flask 應(yīng)用程序的模板中創(chuàng)建一個(gè) HTML 文件來渲染登錄表單,但這超出了代碼示例的范圍。

到此這篇關(guān)于Python3中數(shù)據(jù)校驗(yàn)機(jī)制詳解的文章就介紹到這了,更多相關(guān)Python3數(shù)據(jù)校驗(yàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python獲取指定時(shí)間段內(nèi)特定規(guī)律的日期列表

    python獲取指定時(shí)間段內(nèi)特定規(guī)律的日期列表

    這篇文章主要介紹了python獲取指定時(shí)間段內(nèi)特定規(guī)律的日期列表,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • python爬取”頂點(diǎn)小說網(wǎng)“《純陽劍尊》的示例代碼

    python爬取”頂點(diǎn)小說網(wǎng)“《純陽劍尊》的示例代碼

    這篇文章主要介紹了python爬取”頂點(diǎn)小說網(wǎng)“《純陽劍尊》的示例代碼,幫助大家更好的利用python 爬蟲爬取數(shù)據(jù),感興趣的朋友可以了解下
    2020-10-10
  • tensorflow2.0保存和恢復(fù)模型3種方法

    tensorflow2.0保存和恢復(fù)模型3種方法

    今天小編就為大家分享一篇tensorflow2.0保存和恢復(fù)模型3種方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • python timestamp和datetime之間轉(zhuǎn)換詳解

    python timestamp和datetime之間轉(zhuǎn)換詳解

    這篇文章主要為大家詳細(xì)介紹了python timestamp和datetime之間轉(zhuǎn)換,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • 還不知道Anaconda是什么?讀這一篇文章就夠了

    還不知道Anaconda是什么?讀這一篇文章就夠了

    Anaconda指的是一個(gè)開源的Python發(fā)行版本,其包含了Conda、Python等180多個(gè)科學(xué)包及其依賴項(xiàng),下面這篇文章主要給大家介紹了關(guān)于Anaconda是什么的相關(guān)資料,需要的朋友可以參考下
    2023-02-02
  • 如何在Python中進(jìn)行異常處理

    如何在Python中進(jìn)行異常處理

    這篇文章主要介紹了如何在Python中進(jìn)行異常處理,Python中使用用異常對(duì)象(exception object)表示異常情況,當(dāng)程序運(yùn)行遇到錯(cuò)誤后,就會(huì)觸發(fā)發(fā)異常,下文關(guān)于異常處理的相關(guān)內(nèi)容,需要的小伙伴可以參考一下
    2022-03-03
  • python+pytest接口自動(dòng)化之session會(huì)話保持的實(shí)現(xiàn)

    python+pytest接口自動(dòng)化之session會(huì)話保持的實(shí)現(xiàn)

    在接口測(cè)試的過程中,經(jīng)常會(huì)遇到有些接口需要在登錄的狀態(tài)下才能請(qǐng)求,本文主要介紹了python+pytest接口自動(dòng)化之session會(huì)話保持的實(shí)現(xiàn),感興趣的可以了解一下
    2022-06-06
  • python代碼實(shí)現(xiàn)備忘錄案例講解

    python代碼實(shí)現(xiàn)備忘錄案例講解

    這篇文章主要介紹了python代碼實(shí)現(xiàn)備忘錄案例講解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • python實(shí)現(xiàn)對(duì)AES加密的視頻數(shù)據(jù)流解密的方法

    python實(shí)現(xiàn)對(duì)AES加密的視頻數(shù)據(jù)流解密的方法

    密碼學(xué)中的高級(jí)加密標(biāo)準(zhǔn)(Advanced?Encryption?Standard,AES),又稱Rijndael加密法,這篇文章主要介紹了用python實(shí)現(xiàn)對(duì)AES加密的視頻數(shù)據(jù)流解密,需要的朋友可以參考下
    2023-02-02
  • Python 使用 PyMysql、DBUtils 創(chuàng)建連接池提升性能

    Python 使用 PyMysql、DBUtils 創(chuàng)建連接池提升性能

    DBUtils 是一套 Python 數(shù)據(jù)庫連接池包,并允許對(duì)非線程安全的數(shù)據(jù)庫接口進(jìn)行線程安全包裝。這篇文章主要介紹了Python 使用 PyMysql、DBUtils 創(chuàng)建連接池,提升性能,需要的朋友可以參考下
    2019-08-08

最新評(píng)論