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

Python編程pydantic觸發(fā)及訪問(wèn)錯(cuò)誤處理

 更新時(shí)間:2021年09月29日 09:00:48   作者:小菠蘿測(cè)試筆記  
這篇文章主要為大家介紹了Python編程中pydantic會(huì)觸發(fā)及發(fā)生訪問(wèn)錯(cuò)誤的處理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步

常見(jiàn)觸發(fā)錯(cuò)誤的情況

  • 如果傳入的字段多了會(huì)自動(dòng)過(guò)濾
  • 如果傳入的少了會(huì)報(bào)錯(cuò),必填字段
  • 如果傳入的字段名稱對(duì)不上也會(huì)報(bào)錯(cuò)
  • 如果傳入的類型不對(duì)會(huì)自動(dòng)轉(zhuǎn)換
  • 如果不能轉(zhuǎn)換則會(huì)報(bào)錯(cuò)

錯(cuò)誤的觸發(fā)

pydantic 會(huì)在它正在驗(yàn)證的數(shù)據(jù)中發(fā)現(xiàn)錯(cuò)誤時(shí)引發(fā) ValidationError

注意

驗(yàn)證代碼不應(yīng)該拋出 ValidationError 本身

而是應(yīng)該拋出 ValueError、TypeError、AssertionError 或他們的子類

ValidationError 會(huì)包含所有錯(cuò)誤及其發(fā)生方式的信息

訪問(wèn)錯(cuò)誤的方式

e.errors() :返回輸入數(shù)據(jù)中發(fā)現(xiàn)的錯(cuò)誤的列表

e.json() :以 JSON 格式返回錯(cuò)誤(推薦)

str(e) :以人類可讀的方式返回錯(cuò)誤

簡(jiǎn)單栗子

# 一定要導(dǎo)入 ValidationError
from pydantic import BaseModel, ValidationError 
class Person(BaseModel):
    id: int
    name: str
 try:
    # id是個(gè)int類型,如果不是int或者不能轉(zhuǎn)換int會(huì)報(bào)錯(cuò)
    p = Person(id="ss", name="hallen")  
except ValidationError as e:
  # 打印異常消息
    print(e.errors())

e.errors() 的輸出結(jié)果

[{'loc': ('id',), 'msg': 'value is not a valid integer', 'type': 'type_error.integer'}]

e.json() 的輸出結(jié)果

[
  {
    "loc": [
      "id"
    ],
    "msg": "value is not a valid integer",
    "type": "type_error.integer"
  }
]

str(e) 的輸出結(jié)果

1 validation error for Person
id
  value is not a valid integer (type=type_error.integer)

復(fù)雜栗子

class Location(BaseModel):
    lat = 0.1
    lng = 10.1
class Model(BaseModel):
    is_required: float
    gt_int: conint(gt=42)
    list_of_ints: List[int] = None
    a_float: float = None
    recursive_model: Location = None  
data = dict(
    list_of_ints=['1', 2, 'bad'],
    a_float='not a float',
    recursive_model={'lat': 4.2, 'lng': 'New York'},
    gt_int=21
) 
try:
    Model(**data)
except ValidationError as e:
    print(e.json(indent=4))

輸出結(jié)果

[
    {
        "loc": [
            "is_required"
        ],
        "msg": "field required",
        "type": "value_error.missing"
    },
    {
        "loc": [
            "gt_int"
        ],
        "msg": "ensure this value is greater than 42",
        "type": "value_error.number.not_gt",
        "ctx": {
            "limit_value": 42
        }
    },
    {
        "loc": [
            "list_of_ints",
            2
        ],
        "msg": "value is not a valid integer",
        "type": "type_error.integer"
    },
    {
        "loc": [
            "a_float"
        ],
        "msg": "value is not a valid float",
        "type": "type_error.float"
    },
    {
        "loc": [
            "recursive_model",
            "lng"
        ],
        "msg": "value is not a valid float",
        "type": "type_error.float"
    }
]

value_error.missing:必傳字段缺失

value_error.number.not_gt:字段值沒(méi)有大于 42

type_error.integer:字段類型錯(cuò)誤,不是 integer

自定義錯(cuò)誤

# 導(dǎo)入 validator
from pydantic import BaseModel, ValidationError, validator 
class Model(BaseModel):
    foo: str
 
    # 驗(yàn)證器
    @validator('foo')
    def name_must_contain_space(cls, v):
        if v != 'bar':
            # 自定義錯(cuò)誤信息
            raise ValueError('value must be bar')
        # 返回傳進(jìn)來(lái)的值
        return v 
try:
    Model(foo="ber")
except ValidationError as e:
    print(e.json())

輸出結(jié)果

[
  {
    "loc": [
      "foo"
    ],
    "msg": "value must be bar",
    "type": "value_error"
  }
]

自定義錯(cuò)誤模板類

from pydantic import BaseModel, PydanticValueError, ValidationError, validator 
class NotABarError(PydanticValueError):
    code = 'not_a_bar'
    msg_template = 'value is not "bar", got "{wrong_value}"' 
class Model(BaseModel):
    foo: str
 
    @validator('foo')
    def name_must_contain_space(cls, v):
        if v != 'bar':
            raise NotABarError(wrong_value=v)
        return v
  try:
    Model(foo='ber')
except ValidationError as e:
    print(e.json())

輸出結(jié)果

[
  {
    "loc": [
      "foo"
    ],
    "msg": "value is not \"bar\", got \"ber\"",
    "type": "value_error.not_a_bar",
    "ctx": {
      "wrong_value": "ber"
    }
  }
]

PydanticValueError

自定義錯(cuò)誤類需要繼承這個(gè)或者 PydanticTypeError

以上就是Python編程pydantic觸發(fā)及訪問(wèn)錯(cuò)誤處理的詳細(xì)內(nèi)容,更多關(guān)于pydantic觸發(fā)及訪問(wèn)錯(cuò)誤的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python實(shí)現(xiàn)圖片橫向和縱向拼接

    python實(shí)現(xiàn)圖片橫向和縱向拼接

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)圖片橫向和縱向拼接,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • Python遍歷目錄中的所有文件的方法

    Python遍歷目錄中的所有文件的方法

    Pyhton中我們一般使用os.walk生成器來(lái)獲取文件夾中的所有文件,這里我們就來(lái)詳細(xì)看一下Python遍歷目錄中的所有文件的方法,包括一個(gè)進(jìn)階的利用fnmatch模塊進(jìn)行匹配的方法:
    2016-07-07
  • Python selenium 自動(dòng)化腳本打包成一個(gè)exe文件(推薦)

    Python selenium 自動(dòng)化腳本打包成一個(gè)exe文件(推薦)

    這篇文章主要介紹了Python selenium 自動(dòng)化腳本打包成一個(gè)exe文件,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-01-01
  • python實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲(pygame版)

    python實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲(pygame版)

    這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)pygame版的飛機(jī)大戰(zhàn)游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • Python中Numpy的深拷貝和淺拷貝

    Python中Numpy的深拷貝和淺拷貝

    這篇文章主要介紹了Python中Numpy的深拷貝和淺拷貝,通過(guò)講解Python中對(duì)Numpy數(shù)組操作的淺拷貝和深拷貝的概念和背后的原理展開全文,需要的小伙伴可以參考一下
    2022-05-05
  • Pycharm中無(wú)法使用pip安裝的包問(wèn)題解決方案

    Pycharm中無(wú)法使用pip安裝的包問(wèn)題解決方案

    本文主要介紹了Pycharm中無(wú)法使用pip安裝的包問(wèn)題解決方案,在終端通過(guò)pip裝好包以后,在pycharm中導(dǎo)入包時(shí),依然會(huì)報(bào)錯(cuò),下面就來(lái)介紹一下解決方法
    2023-09-09
  • Python實(shí)現(xiàn)區(qū)間調(diào)度算法

    Python實(shí)現(xiàn)區(qū)間調(diào)度算法

    區(qū)間調(diào)度算法是一種在給定的一組任務(wù)中,選擇盡可能多的相互不沖突的任務(wù)的算法,本文主要介紹了如何使用Python實(shí)現(xiàn)區(qū)間調(diào)度算法,有需要的可以參考下
    2024-10-10
  • Python curses內(nèi)置顏色用法實(shí)例

    Python curses內(nèi)置顏色用法實(shí)例

    在本篇文章里小編給大家整理的是一篇關(guān)于Python curses內(nèi)置顏色用法實(shí)例內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。
    2021-06-06
  • python處理文本文件實(shí)現(xiàn)生成指定格式文件的方法

    python處理文本文件實(shí)現(xiàn)生成指定格式文件的方法

    這篇文章主要介紹了python處理文本文件實(shí)現(xiàn)生成指定格式文件的方法,有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-07-07
  • TensorFlow實(shí)現(xiàn)數(shù)據(jù)增強(qiáng)的示例代碼

    TensorFlow實(shí)現(xiàn)數(shù)據(jù)增強(qiáng)的示例代碼

    ?TensorFlow數(shù)據(jù)增強(qiáng)?是一種通過(guò)變換和擴(kuò)充訓(xùn)練數(shù)據(jù)的方法,本文主要介紹了TensorFlow實(shí)現(xiàn)數(shù)據(jù)增強(qiáng)的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解游戲
    2024-08-08

最新評(píng)論