검증인
검증은 데이터베이스가 각 속성에 적합한 유형의 정보만 수신하는지 확인하는 방법입니다. 결국, 우리는 예상치 못한 유형의 데이터가 코드에 침입하여 예상치 못한 동작을 일으키는 것을 원하지 않을 것입니다. 다행히 SQLAlchemy에는 검증을 빠르고 쉽게 해주는 패키지가 있습니다!
몇 가지 간단한 예를 살펴보겠습니다. 샌드위치라는 간단한 모델이 있다고 상상해 보세요. 여기서는 이미 데이터베이스를 초기화했으며 구성 파일에서 데이터베이스를 가져오고 있습니다.
from config import db class Sandwich(db.Model): __tablename__ = 'sandwiches' id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String) description = db.Column(db.String) price = db.Column(db.Float)
이러한 속성에 유효성 검사를 추가하려면 먼저 유효성 검사 패키지를 가져와야 합니다.
sqlalchemy.orm에서 가져오기 유효성 검사
그런 다음 모델 내부에 '@validates' 데코레이터를 사용하여 함수를 작성합니다.
@validates('name') def validate_name(self, key, value): if not value: raise ValueError('Name cannot be empty.') if type(value) != str: raise ValueError('Name must be a string.') return value
그럼 여기서 무슨 일이 벌어지고 있는 걸까요? 그것을 분석해 봅시다. @validates는 데이터베이스에 추가하기 전에 유효성 검사 기능을 통해 'name' 키로 수신된 값을 전달하도록 ORM에 알리는 데코레이터입니다. 우리가 반환하는 값은 최종적으로 데이터베이스에 제공됩니다. "key" 인수는 평가되는 키입니다. 이 경우 'name'은 값이 해당 키의 값이므로 추가하려는 실제 이름(텍스트로 가능)입니다. 따라서 여기서는 전달된 name 속성이 비어 있지 않은지, 실제로는 문자열인지 확인하고 있습니다. 그렇지 않으면 오류가 발생합니다.
또한 인수에 속성을 추가하여 동일한 데코레이터를 통해 여러 속성을 실행할 수도 있습니다.
@validates('name', 'description') def validate_text(self, key, value): if not value: raise ValueError(f'{key} cannot be empty.') if type(value) != str: raise ValueError(f'{key} must be a string.') return value
이 함수는 이름 및 설명 속성의 유효성을 검사하지만 일반적으로 다른 속성에 대해 동일한 유효성 검사를 수행하지는 않습니다. 우리가 가지고 있는 검증의 종류와 개수에 따라 몇 가지 다른 방법으로 수행할 수 있습니다. 다른 속성에 대해 별도의 유효성 검사기를 실행할 수 있습니다. 설명 및 가격 유효성 검사에도 길이 유효성 검사를 추가해 보겠습니다.
@validates('name') def validate_name(self, key, value): if not value: raise ValueError('Name cannot be empty.') if type(value) != str: raise ValueError('Name must be a string.') return value @validates('description') def validate_description(self, key, value): if not value: raise ValueError('Description cannot be empty.') if type(value) != str: raise ValueError('Description must be a string.') if not 10 <p>또는 두 속성에 대해 동일한 유효성 검사기를 유지하고 전달된 키 인수를 사용하여 각 속성에 대해 실행되는 유효성 검사를 조정할 수 있습니다.<br> </p> <pre class="brush:php;toolbar:false"> @validates('name', 'description', 'price') def validate(self, key, value): if key != 'price: if not value: raise ValueError(f'{key} cannot be empty.') if type(value) != str: raise ValueError(f'{key} must be string.') if key == 'description': if not 10 <p>흠, 좀 지저분하네요. 2개의 별도 유효성 검사기로 리팩터링해 보겠습니다.<br> </p> <pre class="brush:php;toolbar:false"> @validates('name', 'description') def validate_text(self, key, value): if not value: raise ValueError(f'{key} cannot be empty.') if type(value) != str: raise ValueError(f'{key} must be string.') if key == 'description': if not 10 <p>그게 더 좋아요! 완성된 모델은 다음과 같습니다.<br> </p> <pre class="brush:php;toolbar:false">from sqlalchemy.orm import validates from config import db class Sandwich(db.Model): __tablename__ = 'sandwiches' id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String) description = db.Column(db.String) price = db.Column(db.Float) @validates('name', 'description') def validate_text(self, key, value): if not value: raise ValueError(f'{key} cannot be empty.') if type(value) != str: raise ValueError(f'{key} must be string.') if key == 'description': if not 10 <p>그렇습니다! 유효성 검사는 데이터베이스가 올바른 상태로 유지되는지 확인하는 쉬운 도구 중 하나입니다.</p>
위 내용은 검증인의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Python은 게임 및 GUI 개발에서 탁월합니다. 1) 게임 개발은 Pygame을 사용하여 드로잉, 오디오 및 기타 기능을 제공하며 2D 게임을 만드는 데 적합합니다. 2) GUI 개발은 Tkinter 또는 PYQT를 선택할 수 있습니다. Tkinter는 간단하고 사용하기 쉽고 PYQT는 풍부한 기능을 가지고 있으며 전문 개발에 적합합니다.

Python은 배우고 사용하기 쉽고 C는 더 강력하지만 복잡합니다. 1. Python Syntax는 간결하며 초보자에게 적합합니다. 동적 타이핑 및 자동 메모리 관리를 사용하면 사용하기 쉽지만 런타임 오류가 발생할 수 있습니다. 2.C는 고성능 응용 프로그램에 적합한 저수준 제어 및 고급 기능을 제공하지만 학습 임계 값이 높고 수동 메모리 및 유형 안전 관리가 필요합니다.

제한된 시간에 Python 학습 효율을 극대화하려면 Python의 DateTime, Time 및 Schedule 모듈을 사용할 수 있습니다. 1. DateTime 모듈은 학습 시간을 기록하고 계획하는 데 사용됩니다. 2. 시간 모듈은 학습과 휴식 시간을 설정하는 데 도움이됩니다. 3. 일정 모듈은 주간 학습 작업을 자동으로 배열합니다.

Python은 개발 효율에서 C보다 낫지 만 C는 실행 성능이 높습니다. 1. Python의 간결한 구문 및 풍부한 라이브러리는 개발 효율성을 향상시킵니다. 2.C의 컴파일 유형 특성 및 하드웨어 제어는 실행 성능을 향상시킵니다. 선택할 때는 프로젝트 요구에 따라 개발 속도 및 실행 효율성을 평가해야합니다.

Pythonlistsarepartoftsandardlardlibrary, whileraysarenot.listsarebuilt-in, 다재다능하고, 수집 할 수있는 반면, arraysarreprovidedByTearRaymoduledlesscommonlyusedDuetolimitedFunctionality.

파이썬은 자동화, 스크립팅 및 작업 관리가 탁월합니다. 1) 자동화 : 파일 백업은 OS 및 Shutil과 같은 표준 라이브러리를 통해 실현됩니다. 2) 스크립트 쓰기 : PSUTIL 라이브러리를 사용하여 시스템 리소스를 모니터링합니다. 3) 작업 관리 : 일정 라이브러리를 사용하여 작업을 예약하십시오. Python의 사용 편의성과 풍부한 라이브러리 지원으로 인해 이러한 영역에서 선호하는 도구가됩니다.

하루에 2 시간 동안 파이썬을 배우는 것으로 충분합니까? 목표와 학습 방법에 따라 다릅니다. 1) 명확한 학습 계획을 개발, 2) 적절한 학습 자원 및 방법을 선택하고 3) 실습 연습 및 검토 및 통합 연습 및 검토 및 통합,이 기간 동안 Python의 기본 지식과 고급 기능을 점차적으로 마스터 할 수 있습니다.

Python과 C는 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1) Python은 간결한 구문 및 동적 타이핑으로 인해 빠른 개발 및 데이터 처리에 적합합니다. 2) C는 정적 타이핑 및 수동 메모리 관리로 인해 고성능 및 시스템 프로그래밍에 적합합니다.
