Python 웹 개발 라이브러리-빠른 가이드

사용자가 Google Chrome 또는 Mozilla와 같은 웹 브라우저를 열고 '웹 개발'을 검색 할 때마다 수천 개의 결과가 순식간에 나타납니다. 이것이 가능한 이유는 무엇입니까? 웹 개발! 인트라넷 또는 인터넷을 통한 호스팅을 위해 웹 사이트를 구축, 생성 및 유지하는 것과 관련된 작업을 광범위하게 나타냅니다. 웹 사이트 디자인과 관련된 작업에는 웹 프로그래밍, 데이터베이스 관리, 웹 디자인, 웹 게시 등 여러 영역이 포함됩니다.

웹 개발에는 웹 사이트 실행에 영향을주는 모든 코드가 포함됩니다. 웹 개발의 전체 프로세스를 두 가지 범주로 나눌 수 있습니다.

  • Front-end
  • Back-end

프런트 엔드와 백엔드 웹 개발은 확실히 서로 다르지만 동일한 동전의 양면과도 같습니다. 완전한 웹 사이트는 서로가 단일 단위로 효과적으로 통신하고 운영하는 데 의존합니다. 프런트 엔드와 백 엔드 모두 웹 개발에서 똑같이 중요합니다.

애플리케이션의 프런트 엔드 또는 클라이언트 측은 텍스트 색상에서 버튼, 이미지 및 탐색 메뉴에 이르기까지 사용자가 화면에서 직접 경험하는 모든 것을 담당하는 코드입니다. 프런트 엔드 개발자가 사용하는 일반적인 기술과 도구는 다음과 같습니다.

  • HTML/CSS/JavaScript
  • CSS 전 처리기
  • Frameworks
  • Libraries
  • Git 및 Github

일반적으로 응용 프로그램의 백엔드 / 서버 측은 데이터베이스 내의 정보를 관리하고 해당 정보를 프런트 엔드에 제공합니다. 웹 사이트의 백엔드는 서버, 애플리케이션 및 데이터베이스로 구성됩니다. 일반적으로 브라우저를 누르기 전에 일어나는 모든 일이 포함됩니다. 백엔드 웹 개발에 필요한 도구는 다음과 같습니다.

  • Programming language − Ruby, PHP, Python 등

  • Database − MySQL, PostgreSQL, MongoDB, Oracle 등

왜 웹 개발인가?

오늘날 세계에서는 비즈니스 또는 기술을 홍보하고 아이디어를 공유 할 수있는 다양한 선택이 있습니다. 그들 중 일부는 웹 사이트, 마켓 플레이스의 네이티브 애플리케이션 등을 통한 프로모션입니다. 비즈니스 개발 도구로서 새로운 웹 사이트를 만드는 추세는 전 세계적으로 빠르게 추진력을 얻고 있습니다. 그러나 우리 중 일부는 웹 사이트가 비즈니스 성장에있어 중요성을 인식하지 못할 수 있습니다.

현재 공개 시장에서 입지를 구축하기 위해 고군분투하는 스타트 업이 많이 있습니다. 그러나 그들 대부분이 원하는만큼 많은 대상을 확보하지 못하는 것도 사실입니다. 그들을 다운시키는 한 가지 주된 이유는 그들이 사업을 벌기 위해 개발 된 완전한 기능의 웹 사이트의 잠재력을 과소 평가하기 때문입니다. 비즈니스 또는 기타 목적을위한 웹 사이트 개발은 상당한 성과를 거둘 수 있습니다.

웹 사이트 개발이 비즈니스 성장에 중요한 이유 몇 가지를 살펴 보겠습니다.

청중에게 다가 가기

온라인 웹 사이트는 가장 광범위한 사용자에게 다가 갈 수 있으며 기본 애플리케이션을 제한하는 플랫폼으로 제한되지 않습니다. 웹 사이트가 웹 브라우저를 통해 콘텐츠를 표시 할 수 있기 때문에 뷰어 또는 고객은 데스크톱 / 노트북에서 모바일 장치에 쉽게 액세스 할 수 있습니다.

기본 애플리케이션에 비해 웹 브라우징은 사용자가 기기에서 앱 스토어에 액세스하거나 앱을 다운로드 할 필요가 없기 때문에 훨씬 간단합니다 (콘텐츠에 액세스하는 데 하나 이상의 프로세스가 포함될 수 있음). 엄격한 앱 스토어 요구 사항과 따라야 할 콘텐츠 제한이 없기 때문에 네이티브 애플리케이션보다 웹 기반 애플리케이션을 사용하면 데이터 배포가 훨씬 더 유연하고 민첩합니다.

웹 개발에 매우 ​​유용한 또 다른 도구는 SEO 기술을 활용하여 청중을 타겟팅하는 능력입니다.

24/7 액세스 가능

회사를위한 물리적 출구를 구축하는 대신, 사업주가 웹 사이트를 온라인 포럼 또는 이와 유사한 형태로 개발하면 온라인에서 더 많은 잠재 고객을 확보 할 수있는 좋은 기회가 될 것입니다. 대부분의 사람들이 하루 종일 인터넷에 연결되어 있기 때문입니다.

일반적으로 사람들은 가장 현명한 방법으로 온라인을 먼저 확인한 다음 결정을 내리는 것을 선호합니다. 따라서 사업주가 제품의 모든 기본 세부 사항을 작성하고 적시에 제품을 고객에게 제공 할 수있는 안전한 방법을 만든다면 사람들은 매장을 직접 방문하는 대신 온라인 구매를 선호 할 것입니다. 이를 통해 사람들은 하루 중 가장 이상한 시간에도 액세스 할 수 있습니다.

편의

완전한 기능을 갖춘 웹 사이트는 사용자가 항상 조정하고 필요한 것을 찾을 수있는 사용자에게 더 큰 이점을 제공합니다. 일반적으로 사용자는 온라인으로 구매할 수있는 옵션이있는 경우 오프라인 매장에 가지 않습니다. 따라서 똑똑한 사업가라면 웹 사이트에 제품이나 상점에 대한 모든 세부 정보를 포함하여 사업을 벌 수 있지만 그렇지 않으면 그렇지 않을 수도 있습니다.

글로벌 마케팅

온라인 웹 사이트를 통해 소셜 포럼에 연결하고 제품 / 서비스를 전 세계의 수많은 청중에게 마케팅 할 수 있습니다. 이를 통해 정기적으로 소셜 포럼에서 작업을 광고하고 공유하여 대상 고객의 발자취를 훨씬 더 많이 확보 할 수 있습니다.

신뢰할 수있는 출처

온라인 포털은 모든 회사 / 조직에서 가장 신뢰할 수있는 플랫폼입니다. 때로는 공식 웹 사이트가 단독 사무실로 기능 할 수도 있습니다. 회사의 물리적 위치에 액세스하기가 쉽지 않은 시나리오를 고려하십시오. 이 경우 웹 사이트에 집중하여 이러한 걱정을 극복 할 수 있습니다.

간단히 말해서 웹 사이트를 개발하면 몇 번의 클릭만으로 서비스를 홍보 할 수 있으며 전 세계 여러 지역의 소비자의 관심을 끌 수 있습니다. 회사의 웹 사이트는 짧은 시간에 더 많은 청중과 함께 비즈니스를 확보 할 수 있다는 것을 증명할 수 있습니다.

Python은 효율성과 가독성에 중점을두기 때문에 웹 및 애플리케이션 개발자 사이에서 가장 수용 가능한 언어 중 하나입니다. 각각 고유 한 전문성과 기능이있는 뛰어난 Python 웹 프레임 워크가 많이 있습니다.

장고

여기서는 Django 프레임 워크의 몇 가지 필수 세부 사항과 기능에 대해 설명합니다.

Category − Django는 풀 스택 Python 프레임 워크에 속합니다.

Release − 최신 버전 – 2.1 버전, 일반적으로 사용되는 버전 – 1.8, 1.6 버전.

About− 숙련 된 개발자가 구축 한 Django는 빠르고 깔끔하며 실용적인 디자인 개발을 가능하게하는 높은 수준의 Python 웹 프레임 워크입니다. Django는 웹 개발의 복잡성을 상당 부분 처리하므로 바퀴를 다시 만들 필요없이 앱 작성에 집중할 수 있습니다. 무료이며 오픈 소스입니다.

개체를 데이터베이스 테이블에 매핑하기 위해 Django는 ORM을 사용하고 동일한 데이터베이스를 한 데이터베이스에서 다른 데이터베이스로 전송하는 데 사용됩니다.

Oracle, MySQL, PostgreSQL, SQLite 등과 같은 대부분의 중요한 데이터베이스에서 작동합니다.

백엔드 개발을위한 기본 프레임 워크로 Django를 사용하는 수많은 웹 사이트가 업계에 있습니다.

장고의 특징

이 Python 웹 프레임 워크의 대표적인 기능 중 일부는 다음과 같습니다.

  • URL 라우팅
  • Authentication
  • 데이터베이스 스키마 마이그레이션
  • ORM (객체 관계형 매퍼)
  • 템플릿 엔진

Django 프레임 워크의 공식 웹 사이트는 다음과 같습니다.https://www.djangoproject.com/

플라스크

Category − Flask는 Non Full-stack 프레임 워크에 속합니다.

Release − 2018-05-02에 릴리스 된 1.0.2

About− 특정 라이브러리 나 도구가 필요하지 않으므로 마이크로 프레임 워크로 분류됩니다. 양식 유효성 검사 또는 데이터베이스 추상화 계층 또는 기존 타사 라이브러리가 공통 기능을 제공하는 기타 구성 요소가 없습니다. 그러나 flask는 Flask 자체에서 구현 된 것처럼 응용 프로그램 기능을 확장하는 여러 확장을 지원합니다. 객체 관계형 매퍼, 양식 유효성 검사, 업로드 처리, 다양한 개방형 인증 기술 및 여러 공통 프레임 워크 관련 도구에 대한 확장이 존재합니다.

플라스크의 특징

  • 단위 테스트를위한 통합 지원
  • 편안한 요청 발송
  • 개발 서버 및 디버거 포함
  • Jinja2 템플릿 사용
  • 보안 쿠키 지원
  • Unicode-based
  • 100 % WSGI 1.0 준수
  • 광범위한 문서
  • Google App Engine 호환성
  • 원하는 기능을 향상시키기 위해 사용 가능한 확장

Web2py

Category − Web2py는 Full-stack 프레임 워크 제품군에 속합니다.

Release − 2.17.1, 2018-08-06에 출시됨

About− Python 2.6, 2.7 ~ Python 3.x 버전. 더 이상 종속성이 없으므로 그 자체로 완전한 패키지입니다. 애플리케이션의 개발, 데이터베이스 관리, 디버깅, 배포, 테스트 및 유지 관리는 모두 웹 인터페이스를 통해 수행 할 수 있지만 일반적으로 필수는 아닙니다. 코드 편집기, 원 클릭 배포 및 디버거와 함께 자체 웹 기반 IDE와 함께 제공되는 확장 가능한 오픈 소스 프레임 워크입니다.

Web2py의 특징

이 프레임 워크는 개발자의 복잡성을 제거하는 많은 개발 도구 및 기본 제공 기능과 함께 제공됩니다.

  • 설치 및 구성이 없으므로 실행이 쉽습니다.

  • Windows, Unix / Linux, Mac, Google App Engine과 같은 거의 모든 주요 운영 체제와 Python 2.7 / 3.5 / 3.6 / 버전을 통해 거의 모든 웹 호스팅 플랫폼을 지원합니다.

  • MySQL, MSSQL, IBM DB2, Informix, Ingres, MongoDB, SQLite, PostgreSQL, Sybase, Oracle 및 Google App Engine과 쉽게 통신 할 수 있습니다.

  • 교차 사이트 스크립팅, 인젝션 결함 및 악성 파일 실행을 포함하여 가장 일반적인 유형의 취약점을 방지합니다.

  • 오류 추적 및 국제화를 지원합니다.

  • 다중 프로토콜 가독성.

  • 코드를 읽고 유지하기 쉽게 만드는 성공적인 소프트웨어 엔지니어링 사례를 사용합니다.

  • 이전 버전과의 호환성을 통해 사용자 중심의 발전을 보장합니다.

피라미드

Category − Pyramid는 풀 스택이 아닌 프레임 워크입니다.

Release − 1.9.2, 2018-04-23에 출시됨

About− Pyramid는 작고 빠르며 실용적인 Python 웹 프레임 워크입니다. 이것은 Pylons Project의 일부로 개발되었습니다. BSD와 유사한 라이선스에 따라 라이선스가 부여됩니다. 실제 웹 애플리케이션 개발 및 배포를 더욱 재미 있고 예측 가능하며 생산적으로 만듭니다.

피라미드의 특징

Python Pyramid는 다음 기능을 갖춘 오픈 소스 프레임 워크입니다.

  • Simplicity − 누구나 사전 지식없이 작업을 시작할 수 있습니다.

  • Minimalism − 기본적으로 Pyramid에는 거의 모든 웹 애플리케이션에 필요한 몇 가지 중요한 도구 만 함께 제공됩니다. 보안 또는 JavaScript 및 CSS와 같은 정적 자산을 제공하거나 코드에 URL을 첨부 할 수 있습니다.

  • Documentation − 독점적이고 최신 문서를 포함합니다.

  • Speed − 매우 빠르고 정확합니다.

  • Reliability− 보수적이고 철저하게 테스트되었음을 ​​염두에두고 개발되었습니다. 제대로 테스트하지 않으면 고장난 것으로 간주됩니다.

  • Openness − 허용 및 공개 라이선스로 판매됩니다.

대시

Category − Dash 프레임 워크는 "다른"Python 웹 프레임 워크에 속합니다.

Release − 0.24.1, 핵심 대시 백엔드.

About− 대화 형 웹 기반 시각화를 생성하기위한 오픈 소스 라이브러리 인 Dash. 플롯 팀은 Flask, React.js 및 plotly.js를 활용하여 맞춤형 데이터 시각화 앱을 구축하는 오픈 소스 프레임 워크 인 Dash를 만들었습니다. 이 라이브러리의 핵심은 Python 코드를 통해서만 고도의 대화 형 웹 애플리케이션을 빌드 할 수 있다는 것입니다. 데이터 과학자들은 대시 프레임 워크를 좋아합니다. 특히 웹 개발에 익숙하지 않은 모든 사람들이 그렇습니다.

Dash를 사용하면 개발자는 구성 가능한 모든 속성과 기본 Flask 인스턴스에 액세스 할 수 있습니다. Dash 프레임 워크를 사용하여 개발 된 애플리케이션은 서버에 배포 할 수 있으며 결국 웹 브라우저에서 렌더링됩니다.

대시 애플리케이션은 본질적으로 크로스 플랫폼 (Linux / Win / Mac)이며 모바일 친화적이며 애플리케이션의 기능은 다양한 Flask 플러그인 세트로 확장 할 수 있습니다.

대시의 특징

  • 구성 가능한 속성 및 Flask 인스턴스에 대한 액세스를 제공합니다.
  • Flash 플러그인을 통해 Dash 애플리케이션의 기능을 확장 할 수 있습니다.
  • Mobile-ready

이 장에서는 Django Framework에 대해 자세히 설명합니다.

Django는 웹 애플리케이션을 빌드하는 데 사용되는 MVT 웹 프레임 워크입니다. 거대한 Django 웹 프레임 워크에는 많은 "배터리 포함"이 함께 제공되므로 개발자는 모든 것이 어떻게 함께 작동하는지에 대해 놀라게됩니다. 배터리를 너무 많이 추가하는 원리는 후자를 별도의 라이브러리로 추가하는 대신 프레임 워크 자체에 공통 웹 기능을 포함하는 것입니다.

Django 프레임 워크가 인기를 얻은 주된 이유 중 하나는 거대한 Django 커뮤니티입니다. 커뮤니티가 너무 커서 모든 구석의 개발자가 인증, 권한 부여, 본격적인 Django 기반 CMS 시스템, 전자 상거래 추가 기능 등을 포함한 타사 패키지를 개발 한 별도의 웹 사이트가 여기에 전념했습니다. 당신이 개발하려는 것이 이미 누군가에 의해 개발되었고 당신의 프로젝트로 가져 오기만하면 될 가능성이 높습니다.

Django를 사용해야하는 이유는 무엇입니까?

Django는 개발자가 웹 사이트를 빠르고 깨끗하며 실용적인 디자인으로 개발하도록 장려하는 방식으로 설계되었습니다. Django의 실용적인 접근 방식은 군중에서 눈에 띄는 부분입니다.

소셜 미디어 웹 사이트와 같이 고도로 사용자 정의 가능한 앱을 구축 할 계획이라면 Django는 고려할 최고의 프레임 워크 중 하나입니다. Django의 강점은 사용자 간의 상호 작용 또는 다양한 유형의 미디어를 공유하는 능력에 있습니다. django의 가장 큰 장점 중 하나는 애플리케이션에서 플러그인을 사용할 준비가 된 고도로 사용자 정의 가능한 타사를 제공하는 대규모 커뮤니티 기반 지원을 활용할 수 있다는 것입니다.

다음은 웹 개발을 위해 Django를 선택해야하는 10 가지 이유입니다.

파이썬

Python은 간단한 언어 구조, 흐름 구조 및 쉬운 구문으로 인해 배우기 가장 쉬운 프로그래밍 언어 중 하나입니다. 다목적이며 많은 장치에 포함 된 웹 사이트, 데스크톱 응용 프로그램 및 모바일 응용 프로그램을 실행하며 다른 응용 프로그램에서 널리 사용되는 스크립팅 언어로 사용됩니다.

배터리 포함

Django는 URL 라우팅, 인증, 객체 관계형 매퍼 (ORM), 템플릿 시스템 및 db-schema 마이그레이션과 같은 공통 기능을 구축하는 데 필수적인 공통 라이브러리와 함께 제공됩니다.

기본 제공 관리자

Django에는 모델, 사용자 / 그룹 권한을 처리하고 사용자를 관리 할 수있는 내장 관리 인터페이스가 있습니다. 모델 인터페이스를 사용하면 고급 데이터베이스 기능을 제외한 모든 기능에 대해 별도의 데이터베이스 관리 프로그램이 필요하지 않습니다.

당신의 방식을 방해하지 않습니다

Django 애플리케이션을 만들면 상용구와 불필요한 기능이 추가되지 않습니다. 필수 가져 오기, 타사 라이브러리 및 XML 구성 파일이 없습니다.

확장 가능

Django는 MVC 디자인 패턴을 기반으로합니다. 이는 db (데이터베이스), 백엔드 및 프런트 엔드 코드와 같은 모든 엔티티가 개별 엔티티임을 의미합니다. Django를 사용하면 사이트를 구성하는 그림, 파일, CSS 및 JavaScript를 포함한 정적 미디어에서 코드를 분리 할 수 ​​있습니다.

Django는 웹 서버, 캐싱, 성능 관리, 클러스터링 및 균형 조정을위한 타사 라이브러리의 전체 목록을 지원합니다. Django가 제공하는 장점 중 하나는 ReST 및 OAuth와 같은 주요 이메일 및 메시징 애플리케이션과 서비스에 대한 지원입니다.

전투 테스트

Django는 2005 년에 처음 오픈 소스되었습니다. 12 년의 성장 이후 Django는 이제 뉴스 게시 웹 사이트를 운영 할뿐만 아니라 Pinterest, Instagram, Disqus, Bitbucket, EventBrite 및 Zapier와 같은 주요 글로벌 기업의 전체 또는 일부를 운영하고 있습니다. 이를 통해 강력하고 안정적인 웹 프레임 워크를 사용할 수 있습니다.

거대한 패키지 지원

대규모 커뮤니티 지원과 대규모 개발자 네트워크로 인해 원하는 작업이 이전에 수행되었을 가능성이 높습니다. 대규모 국제 개발자 커뮤니티는 프로젝트를 오픈 소스 패키지로 출시하여 커뮤니티에 기여합니다.

이러한 프로젝트의 저장소 중 하나는 Django 패키지 사이트입니다. 현재 Django 패키지에는 3400 개 이상의 Django 프로젝트에 사용할 재사용 가능한 Django 앱, 사이트 및 도구가 나열되어 있습니다.

적극적으로 개발

오픈 소스 프로젝트와 관련된 가장 큰 위험 중 하나는 지속 가능성입니다. 그것이 오래 지속되는지 우리는 확신 할 수 없습니다.

Django는 12 년이 되었기 때문에 그러한 위험이 없습니다. 일관된 릴리스, 더 새롭고 더 나은 버전 및 활발한 커뮤니티는 매일 코드 기반을 유지하고 개선하는 자발적인 기여자로 구성된 대규모 핵심 팀과 함께 매일 성장하고 있습니다.

안정적인 릴리스

Django와 같은 오픈 소스 소프트웨어 프로젝트는 많은 개발자가 매일 개발하고 테스트하기 때문에 경쟁 독점 소프트웨어보다 적극적으로 개발되고 더 안전합니다. 그러나 오픈 소스 소프트웨어 프로젝트의 단점은 상업적으로 실행 가능한 개발을위한 안정적인 코드베이스가 없다는 것입니다.

Django에는 아래 이미지와 같이 소프트웨어의 장기 지원 (LTS) 버전과 정의 된 릴리스 프로세스가 있습니다.

퍼스트 클래스 문서

첫 번째 릴리스부터 Django 개발자는 적절하고 포괄적 인 문서를 사용할 수 있어야하며 튜토리얼을 쉽게 이해할 수 있도록했습니다.

누가 Django를 사용하고 있습니까?

Django의 고유 한 강점으로 인해 Django 프레임 워크 위에 Python으로 빌드 된 여러 인기 웹 사이트가 있습니다. 아래는 Django를 기반으로 전체 또는 부분적으로 구축 된 주요 사이트 중 일부입니다.

Disqus

전 세계적으로 가장 선호되는 블로그 댓글 호스팅 사이트 중 하나입니다. Disqus를 통해 WordPress와 같은 가장 많이 사용되는 CMS (콘텐츠 관리 시스템)와 쉽게 통합 할 수 있습니다. 5 천만 명 이상의 사용자 기반을 관리하는 Django는 사이트 소유자가 커뮤니티에 도달하도록 만족시킬 수 있습니다.

양파

Onion 웹 사이트는 풍자적 인 신문의 온라인 장소를 제공하는 Django는이를위한 프레임 워크를 제공합니다.

Bitbucket

Bitbucket은 버전 관리 저장소 호스팅 서비스 인 GitHub와 같습니다. Bitbucket과 GitHub의 유일한 차이점은 Bitbucket은 mercurial 저장소를 호스팅하는 반면 GitHub는 git 저장소를 호스팅한다는 것입니다. 수백만 명의 사용자가 Bitbucket과 연결되어 있고 bitbucket이 제공하는 모든 서비스 (예 : 저장소 생성, 코드 푸시, 공동 작업자 추가, 커밋, 풀 요청 등)가 안정적이어야합니다. Django는 bitbucket 사이트를 운영합니다.

인스 타 그램

Instagram은 모든 친구에게 사진과 동영상을 공유하는 것을 좋아하는 사람들을 위해 특별히 제작 된 소셜 네트워킹 앱입니다. 현재 인스 타 그램에는 많은 유명인들이 팬들에게 더 가까이 다가 가고 있습니다. Django 프레임 워크도 Instagram을 실행하고 있습니다.

모질라 파이어 폭스

Google 크롬 다음으로 세계에서 두 번째로 널리 사용되는 브라우저는 Mozilla 브라우저입니다. 이제 Mozilla의 도움말 페이지가 Django 프레임 워크로 빌드되었습니다.

핀터 레스트

전 세계 수백만 명의 사용자가 Pinterest에서 새로운 아이디어와 영감을 발견합니다. Pinterest는 Django 프레임 워크 (요구 사항에 따라 수정 완료)를 사용하여 실행합니다.

NASA

미국 항공 우주국의 공식 웹 사이트는 수백만 명의 사용자가 초연 기관에서 제공하는 뉴스, 이미지, 비디오 및 팟 캐스트를 방문하고 확인할 수있는 곳입니다. Django는 공식 NASA 웹 사이트의 특정 부분을 개발합니다.

워싱턴 포스트

세계에 영향력있는 신문이 하나 있다면 워싱턴 포스트 일 것입니다. Washington Post의 웹 사이트는 일간지와 함께 제공되는 매우 인기있는 온라인 뉴스 소스입니다. 엄청난 양의 조회수와 트래픽이 Django 웹 프레임 워크에서 쉽게 처리되었습니다.

레딧 선물

매우 인기있는 Reddit 웹 사이트는 Reddit Gifts라는 익명의 온라인 선물 교환 및 밋업 플랫폼을 시작했습니다. 이 사이트는 전 세계 사용자를 연결하고 이들 간의 선물 교환을 용이하게합니다. Django 웹 프레임 워크는 기능을 강화합니다.

프레지

Prezi는 Django 프레임 워크에 구축 된 Microsoft PowerPoint의 클라우드 기반 대안입니다. 이 사이트는 조작하고 확대 및 축소 할 수있는 가상 캔버스를 제공합니다. 이것은 개별 슬라이드가 아닌 프레젠테이션의 전체보기를 제공합니다.

Django 프로젝트 및 앱 설치 및 만들기

Django를 설치하기 전에 Python이 설치되어 있는지 확인해야합니다. virtualenv를 사용한다고 가정하면 간단한 pip 설치 django로 충분합니다.

가상 환경 및 Django 설치

다음은 Windows 환경에 가상 환경과 Django를 설치하는 프로세스입니다.

Django가 제대로 설치되었는지 확인하려면 아래에 주어진 코드를 입력하십시오.

Django 프로젝트 생성

설치가 완료되면 Django 프로젝트를 만들어야합니다.

Windows 컴퓨터에서 아래 명령을 실행하면 다음과 같은 django 프로젝트가 생성됩니다.

django-admin startproject my_project_name

dir을 입력하면 위에 표시된 것처럼 하나의 새 파일과 하나의 새 디렉토리가 표시됩니다.

manage.py− manage.py는 django-admin을 둘러싼 래퍼 인 명령 줄 실행 가능한 Python 파일입니다. 이름에 내포 된 프로젝트 관리에도 도움이됩니다.

이를 통해 다음과 같은 디렉토리를 생성했습니다. myFirstDjangoProject프로젝트의 구성 루트를 나타내는 myFirstDjangoProject 내부. 더 깊이 탐구 해 보겠습니다.

Django 구성

myFirstDjangoProject 디렉토리 "configuration root"를 호출하면이 디렉토리에 일반적으로 Django 프로젝트를 구성하는 데 필요한 파일이 저장됩니다. 이 디렉토리 외부의 거의 모든 것은 프로젝트의 모델,보기, 경로 등과 관련된 "비즈니스 논리"에만 집중됩니다. 프로젝트를 함께 연결하는 모든 지점이 여기로 이어집니다.

  • __init__.py-이것은 비어 있으며 디렉토리를 가져 오기 가능한 Python 패키지로 변경합니다.

  • settings.py-이름에서 알 수 있듯이 대부분의 구성 항목이 설정되는 곳입니다.

  • urls.py-URL은 urls.py로 설정됩니다. 이를 통해이 파일에 프로젝트의 모든 URL을 명시 적으로 작성할 필요가 없습니다. 그러나 URL이 선언 된 위치를 Django에 알려야합니다 (즉, urls.py에서 다른 URL을 연결해야 함).

  • Wsgi.py-이것은 프로덕션에서 응용 프로그램을 돕기위한 것이며 일부 "앱"개체를 노출하는 Flask, Tornado, Pyramid와 같은 다른 응용 프로그램과 유사합니다.

설정하기

settings.py 내부를 살펴보면 상당한 크기를 알 수 있으며 이는 기본값 일뿐입니다. 주의해야 할 다른 사항은 정적 파일, 데이터베이스, 미디어 파일, 클라우드 통합 또는 Django 프로젝트를 구성 할 수있는 기타 수십 가지 방법입니다. settings.py 파일에 언급 된 몇 가지 사항을 이해해 봅시다.

  • BASE_DIR− 파일을 찾는 데 유용합니다. setting.py 파일 내에서 BASE_DIR 매개 변수는 기본 디렉토리의 절대 경로를 설정합니다.

  • SECRET_KEY− 해시를 만드는 데 사용됩니다. 일반적으로 쿠키, 세션, csrf 보호 및 인증 토큰에 secret_key를 사용했습니다.

  • DEBUG − 개발 또는 프로덕션 모드에서 실행되는 프로젝트로 설정할 수 있습니다.

  • ALLOWED_HOSTS− 당사는 애플리케이션이 제공되는 호스트 이름 목록을 제공합니다. 개발 모드에서 설정하는 것은 선택 사항입니다. 그러나 프로덕션 머신에서는 Django 프로젝트를 설정해야합니다.

  • INSTALLED_APPS− 현재 Django 프로젝트에 설치되어 실행중인 Django "앱"목록입니다. 내장 Django는 다음과 같이 6 개의 설치된 앱을 제공합니다.

    • 'django.contrib.admin'

    • 'django.contrib.auth'

    • django.contrib.

    • django.contrib.sessions

    • django.contrib.messages

    • django.contrib.staticfiles

  • MIDDLEWARE− Django 프로젝트를 실행하는 데 도움이됩니다. django 요청 / 응답 처리에 연결되는 파이썬 클래스입니다.

  • TEMPLATES− 문서가 프런트 엔드에 표시되는 방식을 정의합니다. Django 템플릿은 모든 텍스트 기반 형식을 생성하는 데 사용됩니다.

  • WSGI_APPLICATION− 우리가 설정 한 모든 서버는 WSGI 파일이 어디에 있는지 알아야합니다. 외부 서버를 사용하는 경우 자체 설정으로 표시됩니다. 기본적으로 wsgi.py의 객체를 가리 킵니다.

  • DATABASES− Django 프로젝트가 현재 액세스하고있는 데이터베이스로 설정됩니다. 기본 데이터베이스를 설정하는 것은 필수입니다. 우리가 선택한 데이터베이스를 설정하는 경우 HOST, USER, PASSWORD, PORT, 데이터베이스 이름 및 적절한 ENGINE과 같은 데이터베이스와 관련된 몇 가지 사항을 언급해야합니다.

  • STATIC_URL− STATIC_ROOT에 위치한 정적 파일을 참조 할 때 사용하는 URL입니다. 기본적으로 없음입니다.

그러나 정적 파일에 대한 경로를 추가해야 할 수도 있습니다. 파일의 끝으로 이동하여 STATIC_URL 항목 바로 아래에 아래와 같이 STATIC_ROOT라는 새 항목을 추가합니다.

myFirstDjangoProject/settings.py

STATIC_URL = '/ 정적 /'

STATIC_ROOT = os.path.join (BASE_DIR, '정적')

데이터베이스 설정

사이트에 대한 날짜를 저장할 수있는 다양한 데이터베이스 소프트웨어가 있습니다. 기본값 인 sqlite3을 사용합니다.

이것은 이미 아래 주어진 부분에 설정되어 있습니다. myFirstDjangoProject/settings.py

DATABASES = {
   'default': {
      'ENGINE': 'django.db.backends.sqlite3',
      'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
   }
}

블로그 용 데이터베이스를 생성하기 위해 콘솔에서 다음을 실행 해 보겠습니다. python manage.py migrate (우리는 manage.py 파일을 포함하는 myFirstDjangoProject 디렉토리에 있어야합니다.

모든 것이 잘되면 다음과 같은 출력을 얻을 수 있습니다.

웹 서버 시작

manage.py 파일이 포함 된 디렉토리에 있어야합니다. 콘솔에서 다음과 같이 python manage.py runserver를 실행하여 웹 서버를 시작할 수 있습니다.

이제 웹 사이트가 실행 중인지 확인하기 만하면됩니다. 브라우저 (Firefox, Chrome, Safari, Internet Explorer 또는 사용하는 모든 항목)를 열고이 주소를 입력하십시오.

http://127.0.0.1:8000/

또는

http://localhost:8000/ # 웹 서버는 로컬 머신에서만 실행됩니다.

축하합니다! 방금 첫 번째 웹 사이트를 만들고 웹 서버를 사용하여 실행했습니다!

웹 서버가 실행되는 동안에는 추가 명령을 입력하라는 새 명령 줄 프롬프트가 표시되지 않습니다. 터미널은 다음 텍스트를 받아들이지 만 새 명령을 실행하지는 않습니다. 이는 웹 서버가 들어오는 요청을 수신하기 위해 지속적으로 실행되기 때문입니다.

장고 모델

우리는 블로그에 모든 게시물을 저장할 Django 모델을 만들려고합니다. 그러나 그것이 작동하는지 확인하려면 사물에 대해 배워야합니다.

사물

개체는 속성 및 작업의 모음입니다. 예를 들어 이것을 이해합시다. 고양이를 모델링하고 싶다고 가정하고, 색상, 나이, 기분 (좋음 / 나쁨 / 졸음) 및 소유자와 같은 속성을 가진 Cat이라는 개체를 만듭니다.

그런 다음 고양이는 몇 가지 행동을 취합니다.

Cat 
-------- 
color 
age 
mood 
owner 
purr() 
scratch() 
feed(cat_food) 
CatFood 
-------- 
taste

그래서 기본적으로 우리는 속성 (객체 속성이라고 함)과 액션 (메서드라고 함)을 사용하여 코드에서 실제를 설명하려고합니다.

블로그를 구축 할 때 텍스트 콘텐츠와 제목이 필요합니다. 또한 저자의 이름, 작성일, 발행일이 필요합니다.

따라서 블로그에는 다음과 같은 객체가 있습니다.

Post 
-------- 
title 
text 
author 
created_date 
published_date

또한 해당 게시물을 게시하는 몇 가지 방법이 필요합니다. 이제 객체가 무엇인지 알고 있으므로 블로그 게시물을위한 Django 모델을 만들 수 있습니다.

모델은 Django에서 특별한 종류의 객체이며 데이터베이스에 저장됩니다. 데이터를 SQLite 데이터베이스에 저장합니다.

응용 프로그램 만들기

모든 것을 명확하게 유지하기 위해 프로젝트 내에 별도의 응용 프로그램을 만들 것입니다. 아래에서는 아래에 언급 된 간단한 명령을 실행하여 블로그 웹 응용 프로그램을 만들어 보겠습니다.

이제 새 myBlog 디렉토리가 생성되고 여기에 여러 파일이 포함되어 있음을 알 수 있습니다. 프로젝트의 디렉토리와 파일은 다음과 같아야합니다.

응용 프로그램을 만든 후에는 Django에게 사용하도록 지시해야합니다. myFirstDjangoProject / settings.py 파일에서이를 수행합니다.

INSTALLED_APPS = [
   'django.contrib.admin',
   'django.contrib.auth',
   'django.contrib.contenttypes',
   'django.contrib.sessions',
   'django.contrib.messages',
   'django.contrib.staticfiles',
   'myBlog',
]

블로그 게시물 모델 만들기

에서 myBlog/models.py 파일에서 Models라는 모든 개체를 정의합니다. 여기에서 블로그 게시물을 정의합니다.

myBlog / models.py를 열고 모든 것을 제거하고 다음과 같이 코드를 작성해 보겠습니다.

첫째, from 또는 import를 호출하여 다른 파일에서 일부 기능을 가져옵니다. 따라서이를 통해 모든 파일에 동일한 내용을 복사하여 붙여 넣는 대신 다음과 같은 일부 부분을 포함 할 수 있습니다.from and import.

class Post(models.Model) −이 선은 모델을 정의합니다 (객체).

  • class는 객체를 정의하고 있음을 나타내는 특수 키워드입니다.

  • Post는 우리 모델의 이름입니다. 항상 대문자로 클래스 이름을 시작하십시오.

  • models.Model은 Post가 Django 모델임을 의미하므로 Django는 데이터베이스에 저장되어야 함을 알고 있습니다.

이제 위에서 정의한 속성 인 title, text, created_date, published_date 및 author에 대해 논의하겠습니다. 이를 위해 각 필드의 유형을 정의해야합니다.

  • models.CharField-제한된 수의 문자로 텍스트를 정의하는 방법입니다.

  • Models.TextField-이것은 제한이없는 긴 텍스트입니다.

  • Models.DateTimeField-이것은 날짜와 시간입니다.

  • Models.ForeignKey-이것은 다른 모델에 대한 링크입니다.

함수 / 방법을 다음과 같이 정의합니다. def 그리고 publish는 메소드의 이름입니다.

메서드는 종종 무언가를 반환합니다. 여기서 __str __ ()을 호출하면 Post 제목이있는 텍스트 (문자열)를 얻을 수 있습니다.

데이터베이스에서 모델에 대한 테이블 만들기

마지막 단계는 데이터베이스에 새 모델을 추가하는 것입니다. 먼저, Django가 모델을 변경했음을 이해하도록해야합니다. 콘솔 창에서 명령을 사용하여 동일한 작업을 수행하겠습니다.python manage.py make migrations myBlog 아래와 같이-

그런 다음 Django는 이제 데이터베이스에 적용해야하는 마이그레이션 파일을 준비합니다. 콘솔에서 다음을 입력 할 수 있습니다.python manage.py migrate myBlog 출력은 다음과 같아야합니다.

이제 Post 모델이 데이터베이스에 있습니다.

장고 관리자

방금 모델링 한 게시물을 추가, 편집 및 삭제하기 위해 Django 관리자를 사용하고 있습니다.

그래서 우리는 myBlog/admin.py file 그리고 아래에 내용을 넣으십시오-

먼저, 이전 장에서 정의한 Post 모델을 가져옵니다 (포함). 모델을 관리자 페이지에 표시하려면 admin.site.register (Post)에 모델을 등록해야합니다.

관리자 사이트에 로그인하려면 사이트의 모든 것을 제어 할 수있는 사용자 계정 인 수퍼 유저를 만들어야합니다. 따라서 웹 서버를 중지하고 명령 줄 python을 입력하십시오.manage.py createsuperuser를 입력하고 Enter를 누르십시오.

이제 Post 모델을 살펴볼 시간입니다. 웹 서버를 실행하려면 콘솔에서 python manage.py run server를 실행해야합니다. 브라우저로 이동하여 주소를 입력하십시오.https://127.0.0.1:8000/admin/.방금 선택한 자격 증명으로 로그인하십시오. 그러면 아래와 같이 Django 관리 대시 보드가 표시됩니다.

게시물로 이동하여 약간 실험 해보십시오. 어디에서나 많은 블로그 게시물과 콘텐츠를 추가 할 수 있습니다. 귀하의 블로그는 다음과 같습니다.

이것은 Django의 개요 일 뿐이며 몇 줄의 코드만으로 블로그를 만들 수 있습니다.

Flask는 외부 라이브러리에 거의 의존하지 않는 마이크로 프레임 워크입니다. 매우 가벼운 프레임 워크이며 우리가 원하는 것을 할 수있는 자유를줍니다.

이 장에서는 Python 및 Flask 프레임 워크를 사용하여 프로젝트를 빌드 할 것입니다.

Flask 시작 및 구성

가장 널리 사용되는 Python 라이브러리와 마찬가지로 Flask 패키지는 PPI (Python Package Index)에서 설치할 수 있습니다. 먼저 디렉토리를 생성 해 보겠습니다 (이 장에서는flaskProject) 그런 다음 가상 환경을 생성하고 flaskEnv) 모든 프로젝트 관련 종속성이로드됩니다 (플라스크 포함). 또한 flask-sqlalchemy를 설치하여 flask 애플리케이션이 SQL 데이터베이스와 통신하는 간단한 방법을 가질 수 있습니다.

플라스크를 설치하면 flaskEnv (virtualEnvironment 이름)가 아래와 같이 표시됩니다.

플라스크로 앱 만들기

플라스크를 설치하면 간단한 "hello application in flask”다음과 같이 코드가 매우 적습니다.

터미널에 다음을 입력하십시오-

$python flaskapp.py

그리고 다음 출력을 볼 수 있습니다.

실행 중 http://127.0.0.1:5000/ 또는 localhost:5000

다음은 예제 코드에서 수행 한 작업에 대한 설명입니다.

  • 먼저 Flask 클래스 라이브러리를 가져옵니다. 이 클래스의 인스턴스는 WSGI 앱입니다.

  • 둘째,이 클래스의 인스턴스를 만듭니다. 애플리케이션 패키지 또는 모듈 이름은 첫 번째 인수입니다. 플라스크는 정적 파일, 템플릿 및 기타 파일을 찾을 위치를 알고 있어야합니다.

  • 다음은 어떤 URL이 메소드 / 함수를 트리거해야하는지 알기 위해 사용하는 route () 데코레이터입니다.

URL 라우팅 생성

URL 라우팅을 사용하면 웹 앱의 URL을 쉽게 기억할 수 있습니다. 이제 몇 가지 URL 경로를 생성합니다.

/hello
/members
/members/name

위의 URL을 기반으로 다음 코드를 작성하고 app.py로 저장할 수 있습니다.

from flask import Flask, render_template

app = Flask(__name__)

@app.route('/')
def index():
   return "Index!"
	
@app.route('/Hello')
def hello():
   return "Hello, World!"
	
@app.route("/members")
def members():
   return "Members"
	
@app.route("/members/<name>/")
def getMember(name):
   return name
	
if __name__ == '__main__':
   app.run(debug=True)
$ python app.py

Running on http://localhost:5000/

브라우저에 다음과 같은 출력이 표시됩니다.

다음과 같이 브라우저에서 다른 URL을 시도 할 수 있습니다.

Running on http://localhost:5000/hello, will give the following output −

Running on http://localhost:5000/members, will give −

Running on http://localhost:5000/members/TutorialsPoint/, will give you the following output −

그러나 일반적으로 우리는 (위와 같이) 문자열을 반환하고 싶지 않으며 템플릿을 반환합니다. 이를 위해 우리는 "render_template”을 입력하고 render_template을 일부 입력으로 반환합니다. 그래서 아래 함수는 우리의 일을 할 것입니다.

from flask import render_template
return render_template(‘home.html’)

폴더 템플릿을 만들고 그 안에 home.html 파일을 배치하겠습니다.

다음으로 레이아웃에 대해 설명합니다. 모든 단일 템플릿에 html head 태그와 body 태그를 사용하는 대신 head & body 태그를 포함하고 현재 뷰 또는 현재 템플릿을 래핑하는 레이아웃을 디자인합니다. 이를 위해 하나의 별도 파일을 생성하고layout.html. 여기에 일반 헤드 태그, 본문 태그 및 기타 모든 필수 태그를 넣을 수 있습니다.

다음 코드 줄로 새 layout.html을 만들 수 있습니다.

<!DOCTYPE html>
<html>
   <head>
      <meta charset="utf-8">
      <title>MyFlaskApp</title>
      <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css">
   </head>
   <body>
      {% include 'includes/_navbar.html' %}
      <div class="container">
      {% block body %}
      {% endblock %}
      </div>
      <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js">
      </script>
   </body>
</html>

위의 코드에서는 타이틀 트랙 인 MyFlaskAp를 지정하고 헤드에 css cdn을 사용하고 본문 블록에 javascript를 사용하여 부트 스트랩을 활성화했습니다.

이제 모든 페이지에 대해 navbar를 만들어야합니다. 이를 위해 먼저 include 폴더를 만든 다음 그 안에 _navbar.html 파일을 만들어야합니다. 이제 _navbar.html에서 getbootstrap.com의 표준 스타터 템플릿을 사용해야합니다. 새로 생성 된 _navbar.html 파일은 다음과 같습니다.

그리고이 _navbar.html 파일을 layout.html 파일에 포함 시키십시오.

{% include 'includes/_navbar.html' %}

레이아웃 블록이 있으므로 홈 파일 (home.html)에서이 블록을 확장 할 수 있습니다.

home.html 파일은 아래 코드를 사용하여 만들 수 있습니다.

{% extends 'layout.html' %}
{% block body %}
   <div class="jumbotron text-center">
      <h1>Welcome to FlaskApp</h1>
      <p>This application is built on Flask webframework!</p>
   </div>
{% endblock %}

우리가 flaskapp.py 파일을 실행하려고하면 이것을 사용하면 브라우저에서 아래 출력을 볼 수 있습니다.

이제 활성화하고 싶습니다 (현재 탭이 작동하지 않음). about탭. about 탭에 대한 경로를 만들고 템플릿 파일을 만듭니다.about.html.

appflask.py의 탭 경로는 다음과 같습니다.

about.html 파일에는 다음 내용이 있습니다.

이제 Home 및 About이 처리됩니다. 기사의 경우 루트 디렉토리에 새 파일 (data.py)을 생성 할 수 있습니다. 여기서 데이터를 저장하고 웹 페이지에서 호출합니다.

data.py

def Articles():
   articles = [
      {
         'uid': 1,
         'title': 'Article_One',
         'body': 'Flask, being a microframework, often requires some repetitive step
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Rajesh Joshi',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 2,
         'title': 'Article_Two',
         'body': "Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could 
            be abstracted to support multiple projects the Flask Extension Registry 
            was created.",
         'Author': 'Rajesh J',
         'Created-on': '07-09-2018'
      },
      {
         'uid': 3,
         'title': 'Article_Three',
         'body': 'Flask, being a microframework, often requires some repetitive steps
            to get a third party library working. Because very often these steps could be
            abstracted to support multiple projects the Flask Extension Registry 
            was created.',
         'Author': 'Joshi Rajesh',
         'Created-on': '07-09-2018'
      }
   ]
   return articles

아래는 articles.html, 각 uid에 대한 기사 제목을 표시합니다.

{% extends 'layout.html' %}
{% block body %}
   <h1>Articles</h1>
   {% for article in articles %}
      <li class="list-group-item">
         <a href="article/{{article.uid}}"> {{article.title}}</a>
      </li>
   {% endfor %}
{% endblock %}

요약하면, Flask는 가볍기 때문에 가장 인기있는 파이썬 웹 프레임 워크 중 하나입니다. 마이크로이지만 확장 가능한 파이썬 웹 프레임 워크입니다. 필요한 기능을 제공함으로써 flask는 간단한 웹 애플리케이션의 개발을 가속화합니다. 따라서 Flask는 작고 덜 복잡한 응용 프로그램에 더 적합합니다.

Web2py는 사용하기 쉬운 프레임 워크입니다. web2py를 사용하면 휴대용이고 USD 드라이브에서도 실행할 수 있으므로 설치 및 구성이 필요하지 않습니다. 다른 많은 파이썬 프레임 워크와 마찬가지로 MVC 프레임 워크를 기반으로합니다. 대부분은 이전 버전의 Python을 지원하지 않지만 web2py는 여전히 이전 버전 인 python 2.6 및 2.7을 지원합니다. 또한 요즘 널리 사용되는 인증 용 LDAP도 지원합니다.

Web2py는 세 가지 주요 목표에 초점을 맞춰 웹 개발 진입 장벽을 낮추려고합니다.

  • 급속 성장
  • 사용의 용이성
  • Security

사용자 관점을 염두에두고 Web2py는 이전 버전과의 호환성 지원을 포함하여 더 빠르고 간결한 프레임 워크를 만들기 위해 구축되고 지속적으로 내부적으로 최적화됩니다.

Web2py 프레임 워크 설치 및 구성

web2py를 실행하는 것은 쉽습니다. 아래 링크에서 exe를 다운로드해야합니다. http://www.web2py.com/init/default/download

Windows의 경우 zip 파일을 다운로드하고 압축을 풀고 exe 파일을 직접 또는 명령 줄에서 실행할 수 있습니다. 관리자 암호를 묻는 아래 화면이 표시됩니다.

관리자 암호를 선택하고 서버를 시작할 수 있습니다. 다음 화면이 표시됩니다-

Web2py를 사용하여 앱 만들기

이제 새 앱을 만들 준비가되었습니다. 하단에있는 관리 탭을 클릭하십시오. 따라서 관리자 비밀번호를 입력하면 아래 화면이 나타납니다.

새로운 간단한 애플리케이션으로 이동하여 일부 애플리케이션 이름 (예 : helloWeb2py)을 입력하고 만들기를 클릭합니다. 그러면 아래와 같이 디자인 인터페이스 페이지가 표시됩니다.

현재 라이브 웹인 helloWeb2py로 이동하여 간단히 입력 할 수도 있습니다. http://127.0.0.1:8000/helloWeb2py 로컬 컴퓨터에서 다음과 같은 출력을 얻을 수 있습니다.

helloWeb2py 애플리케이션의 디자인 페이지에서 컨트롤러로 이동하여 default.py 옆에있는 편집 버튼을 클릭합니다. index () 함수의 반환 값을 변경하면 다음 출력이 표시됩니다.

변경 사항을 저장하면 이제 helloWeb2py 앱에서 변경된 사항을 확인할 수 있습니다. 새로 고침http://127.0.0.1:8000/helloWeb2py 링크를 클릭하면 아래 출력이 표시됩니다.

클라우드 플랫폼에 앱 배포

이제 클라우드 플랫폼에 앱을 배포하려면 홈 페이지로 돌아와 사이트를 클릭하십시오. 배포 옵션을 선택할 수 있습니다. 여기서는 "pythonAnywhere"를 선택합니다. pythonAnywhere 웹 사이트로 이동하여 등록하십시오 (아직 등록하지 않은 경우). 클릭“Add a new web app”모든 자격 증명을 입력합니다 (web2py 앱 선택). 모두 완료되었습니다.

이제 이동 https://username.pythonanywhere.com/welcome/default/index, 관리자 탭을 클릭합니다 (비밀번호 입력). 다음으로 업로드를 클릭하고 압축 된 애플리케이션을 설치합니다. 아래와 같이 자격 증명을 입력하고 설치를 클릭합니다.

모든 작업이 완료되면 아래와 같은 팝업 메시지가 나타납니다.

이제 앱을 보려면 아래 링크를 엽니 다.

https://username.pythonanywhere.com/welcome/default/index 다음 화면을 볼 수 있습니다.

첫 번째 web2py 애플리케이션이 성공적으로 생성 및 배포되었습니다.

요약하면, Web2py는 전적으로 파이썬으로 작성되었으며 가능한 모든 방법 (모델, 뷰, 컨트롤러)에서 파이썬 사용을 권장하는 무료, 빠르고 안전한 웹 개발 프레임 워크입니다. 소규모 웹 애플리케이션 또는 프로토 타입을위한 매우 좋은 프레임 워크이지만 엔터프라이즈 급 품질 요구 사항을 충족하지 못합니다. 엔터프라이즈 수준의 응용 프로그램에서는 단위 테스트의 부족, 정확하고 정확한 오류보고 및 분산 된 모델로 인해 버그 해결의 복잡성이 기하 급수적으로 증가하기 때문입니다.

Pyramid는 Python으로 구축 된 일반적인 오픈 소스 웹 애플리케이션 개발 프레임 워크입니다. 파이썬 개발자는 웹 애플리케이션을 쉽게 만들 수 있습니다.

설치, 시작 및 구성

"작게 시작하고, 크게 끝내고, 완성 된 프레임 워크를 유지하십시오"라고 설명했듯이 Pyramid는 설치 및 실행에 거의 노력이 들지 않는 Flask와 매우 유사합니다. 실제로이 애플리케이션을 빌드하기 시작하면 일부 패턴이 Flask와 유사하다는 것을 알게 될 것입니다.

다음은 피라미드 프레임 워크 환경을 만드는 단계입니다.

  • 먼저 프로젝트 디렉토리를 만듭니다. 여기에서 우리는pyramidProject (원하는 이름을 선택할 수 있습니다).

  • 다음으로 모든 프로젝트 별 종속성을 설치할 가상 환경을 만듭니다. 여기에서 가상 환경 폴더를 만들었습니다.pyramidEnv 피라미드가 설치된 곳.

  • 그런 다음 디렉토리로 이동하여 pyramidEnv 피라미드를 설치하십시오 pip install pyramid.

위에서 언급 한대로 모든 작업이 완료되면 디렉토리 구조는 다음과 같습니다.

그리고 시스템에 설치된 피라미드 버전은 다음과 같습니다.

핵심 개념

피라미드 프레임 워크는 아래의 핵심 개념을 기반으로합니다.

  • Zope (확장 성, 순회, 선언적 보안)-Pyramid는 확장 성, 순회 개념 및 선언적 보안 측면에서 Zope를 기반으로합니다.

  • Pylons(URL 디스패치, 지속성, 템플릿 등에 대한 의견없는 관점)-피라미드가 개념을 그리는 또 다른 영역은 pylons 프로젝트입니다. Pylons는 피라미드 프레임 워크 내에서 URL 디스패치를 ​​호출하는 경로 개념을 가지고 있으며 지속성 레이어 또는 템플릿에 대해 의견이없는 뷰를 가지고 있습니다.

  • Django(보기, 문서 수준) − Pyramid는 Django에서도 힌트를 얻습니다. 우리가 우리의 관점을 취하고, URL을 라우팅하고, 문서 수준을 지정하는 방식은 매우 Django 방식입니다.

다음은 피라미드 프레임 워크의 기능입니다-

  • 가장 빠르게 알려진 Python 웹 프레임 워크입니다.

  • 소규모 및 대규모 프로젝트를 지원합니다 (작은 프레임 워크를 초과 할 때 다시 작성해야하는 이유).

  • 마이크로 프레임웍 스와 같은 단일 파일 웹앱을 지원합니다.

  • 기본 제공 세션이 있습니다.

  • Plone / Zope와 유사한 이벤트를 지원합니다.

  • 트랜잭션 관리를 제공합니다 (이전에 Zope를 사용한 적이있는 경우).

구성

구성은 응용 프로그램 작동에 영향을주는 설정입니다. 피라미드 애플리케이션을 구성하는 방법에는 명령형 구성과 선언적 구성의 두 가지가 있습니다.

피라미드 구성 지원-

  • 명령형 구성 또는 데코레이터 기반 구성 재정의

  • 구성 충돌 감지 (더 많은 로컬 결정과 적은 로컬 결정 포함)

  • 구성 확장 성 (여러 앱에서 포함)

  • 유연한 인증 및 권한 부여 정책

  • 프로그래밍 방식의 구성 검사 (탐색을 생성하기 위해 경로의 현재 상태보기)

URL 생성

피라미드에서는 경로, 리소스 및 정적 자산에 대한 URL을 생성 할 수 있습니다. URL 생성 API로 작업하는 것은 쉽고 유연합니다. 피라미드의 다양한 API를 통해 URL을 생성함으로써 사용자는 웹 페이지와의 링크가 끊어 질 염려없이 임의로 구성을 변경할 수 있습니다.

간단히 말해서 피라미드의 URL-

  • 링크를 끊지 않는 앱을 ​​변경할 수 있도록 URL 생성을 지원합니다.

  • 애플리케이션 내부 또는 외부에있는 정적 리소스에 대한 URL을 생성합니다.

  • Routes 및 Traversal을 지원합니다.

견해

피라미드의 주요 작업 중 하나는 요청이 애플리케이션에 도달 할 때 호출 가능한 뷰를 찾아 호출하는 것입니다. 뷰 콜 러블은 애플리케이션의 요청에 대한 응답으로 흥미로운 작업을 수행하는 코드입니다.

뷰를 URL 디스패치 또는 파이썬 코드에 매핑 할 때 모든 종류의 호출이있을 수 있습니다. 뷰는 함수 선언 또는 인스턴스 일 수 있으며 피라미드에서 뷰로 사용할 수 있습니다.

보기에 대한 몇 가지 중요한 사항은 다음과 같습니다.

  • 모든 콜 러블에서 뷰가 생성됩니다.

  • 렌더러 기반 뷰는 단순히 사전을 반환 할 수 있습니다 (webby 스타일 객체를 반환 할 필요가 없음).

  • 경로당 여러보기를 지원합니다 (GET vs. POST vs. HTTP 헤더 검사 등).

  • 응답 어댑터를 봅니다 (보기 반환 값을 처리해야하는 방법과 응답 개체를 비교하려는 경우).

확장 성

Pyramid는 확장 성을 염두에두고 설계되었습니다. 따라서 피라미드 개발자가 애플리케이션을 빌드하는 동안 특정 제약 조건을 염두에두고 있다면 제 3자가 소스 코드를 수정할 필요없이 애플리케이션의 동작을 변경할 수 있어야합니다. 특정 제약 조건을 따르는 피라미드 응용 프로그램의 동작은 수정없이 재정의하거나 확장 할 수 있습니다. 여러 환경에 유연하게 배포 할 수 있도록 설계되었습니다 (싱글 톤 없음). Pyramid는 "Tweens"미들웨어를 지원합니다 (WSGI 미들웨어이지만 Pyramid 자체의 컨텍스트에서 실행 됨).

Hello, Pyramid 프로그램 실행

모든 것이 제대로 작동하는지 확인하기 위해 피라미드 프레임 워크를 설치 한 후 생각할 수있는 가장 간단한 프로그램은 간단한 "Hello, World"또는 "Hello, Pyramid"프로그램을 실행하는 것입니다.

아래는 8000 번 포트 번호의 피라미드“Hello, Pyramid”프로그램입니다.

위의 간단한 예는 실행하기 쉽습니다. 이 파일을 app.py로 저장합니다 (여기서는 pyramid_helloW.py라는 이름을 지정했습니다).

가장 간단한 프로그램 실행 : −

다음으로 http://localhost:8000/브라우저에서 Hello, Pyramid! 다음과 같은 메시지-

다음은 위의 코드에 대한 설명입니다.

라인 번호. 1-3

파일 헤드에는 import 문이 있습니다. 첫 번째 줄은 응용 프로그램에 전달 될 때 간단한 웹 서버를 만들 수있는 make_server 함수를 가져옵니다. 두 번째 및 세 번째 줄은 피라미드에서 구성 및 응답 함수를 가져옵니다. 이러한 기능은 애플리케이션에 대한 세부 정보를 구성하고 매개 변수를 설정하고 요청에 각각 응답하는 데 사용됩니다.

라인 번호. 5-6

이제 우리는 hello_world. 응답을 생성하는보기 코드를 구현하십시오. 뷰의 요구 사항을 충족하는 함수는 요청 엔터티로 다시 전달 될 텍스트를 렌더링합니다. 위의 경우 함수가 호출되면 이전에 가져온 Response 함수를 사용합니다. 이것은 클라이언트에 제공되어야하는 값을 다시 전달합니다.

라인 번호. 8

if __name__ == '__main__': 파이썬은이 모듈을 가져올 때가 아니라 "명령 줄에서 실행할 때 여기에서 시작"이라고 말합니다.

라인 번호. 9-11

라인 번호. 9에서는 프로그램 상단에서 가져온 configurator 함수로 생성 한 객체에서 config라는 변수를 생성합니다. 10 행과 11 행은이 객체의 add_route 및 add_view 메소드를 호출합니다. 이 메소드는 애플리케이션에서 사용할 수있는보기를 정의하는 데 사용됩니다. 보시다시피 앞서 정의한 hello_world 함수를 전달합니다. 이 기능이 실제로 뷰로 통합되는 곳입니다.

라인 번호. 12-14

여기서는 실제로 config 개체의 make_wsgi_app 메서드를 호출하여 WSGI 응용 프로그램을 만듭니다. 이것은 우리가 추가 한 뷰와 같은 객체의 속성을 사용하여 애플리케이션을 생성합니다. 그런 다음이 애플리케이션은 애플리케이션을 제공하기 위해 웹 서버를 시작할 수있는 객체를 생성하기 위해 가져온 make_server 함수로 전달됩니다. 마지막 줄은이 서버를 시작합니다.

우리의 hello world application"필수적으로"구성된 가장 간단하고 쉬운 피라미드 응용 프로그램 중 하나입니다. 구성 작업을 수행 할 때 Python의 모든 기능을 사용할 수 있기 때문에 필수적입니다.

요약하면 Pyramid는 크고 활동적인 커뮤니티가있는 오픈 소스 Python 웹 프레임 워크입니다. 이 대규모 커뮤니티는 Python 웹 프레임 워크를 대중적이고 관련성있게 만드는 데 기여합니다. Pyramid 웹 프레임 워크는 강력한 기능 및 도구 세트를 제공하여 웹 애플리케이션 개발을 단순화하고 가속화합니다.

이 장에서는 Dash 프레임 워크에 대해 자세히 설명합니다.

Dash는 분석 웹 애플리케이션을 구축하는 데 사용되는 오픈 소스 Python 프레임 워크입니다. 데이터 기반 애플리케이션의 개발을 단순화하는 강력한 라이브러리입니다. 웹 개발에 익숙하지 않은 Python 데이터 과학자에게 특히 유용합니다. 사용자는 대시를 사용하여 브라우저에서 멋진 대시 보드를 만들 수 있습니다.

Plotly.js, React 및 Flask 위에 구축 된 Dash는 드롭 다운, 슬라이더 및 그래프와 같은 최신 UI 요소를 분석 Python 코드에 직접 연결합니다.

대시 앱은 HTTP 요청을 통해 JSON 패킷을 사용하여 프런트 엔드 React 구성 요소와 통신하는 Flask 서버로 구성됩니다.

대시 애플리케이션은 순수하게 Python으로 작성되므로 HTML이나 JavaScript가 필요하지 않습니다.

대시 설정

Dash가 터미널에 아직 설치되지 않은 경우 아래 언급 된 Dash 라이브러리를 설치하십시오. 이러한 라이브러리는 개발 중이므로 자주 설치하고 업그레이드하십시오. Python 2 및 3도 지원됩니다.

  • pip install dash == 0.23.1 # 핵심 대시 백엔드
  • pip install dash-renderer == 0.13.0 # 대시 프런트 엔드
  • pip install dash-html-components == 0.11.0 # HTML 구성 요소
  • pip install dash-core-components == 0.26.0 # 강력한 구성 요소
  • pip install plotly == 3.1.0 # 플롯 그래프 라이브러리

모든 것이 제대로 작동하는지 확인하기 위해 간단한 dashApp.py 파일을 만들었습니다.

대시 또는 앱 레이아웃

대시 앱은 두 부분으로 구성됩니다. 첫 번째 부분은 기본적으로 응용 프로그램의 모양을 설명하는 응용 프로그램의 "레이아웃"입니다. 두 번째 부분에서는 응용 프로그램의 상호 작용에 대해 설명합니다.

핵심 구성 요소

레이아웃을 만들 수 있습니다. dash_html_components 그리고 dash_core_components도서관. Dash는 애플리케이션의 모든 시각적 구성 요소에 대한 Python 클래스를 제공합니다. JavaScript 및 React.js로 자체 구성 요소를 사용자 정의 할 수도 있습니다.

dash_core_components를 dcc로 가져 오기

dash_html_components를 html로 가져 오기

dash_html_components는 모든 HTML 태그 용이며 dash_core_components는 React.js로 빌드 된 상호 작용 용입니다.

위의 두 라이브러리를 사용하여 아래와 같이 코드를 작성해 보겠습니다.

app = dash.Dash()
app.layout = html.Div(children=[
   html.H1(children='Hello Dash'),
   html.Div(children='''Dash Framework: A web application framework for Python.''')

그리고 동등한 HTML 코드는 다음과 같습니다.

<div>
   <h1> Hello Dash </h1>
   <div> Dash Framework: A web application framework for Python. </div>
</div>

Simple Dash 앱 작성

파일에서 위에서 언급 한 라이브러리를 사용하여 대시에 간단한 예제를 작성하는 방법을 배웁니다. dashApp.py.

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()
app.layout = html.Div(children=[
   html.H1(children='Hello Dash'),
   html.Div(children='''Dash Framework: A web application framework for Python.'''),
	
   dcc.Graph(
      id='example-graph',
      figure={
         'data': [
            {'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
            {'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
         ],
         'layout': {
            'title': 'Dash Data Visualization'
         }
      }
   )
])

if __name__ == '__main__':
   app.run_server(debug=True)

Dash 앱 실행

Dash 앱을 실행하는 동안 다음 사항에 유의하십시오.

(MyDjangoEnv) C : \ Users \ rajesh \ Desktop \ MyDjango \ dash> python dashApp1.py

  • Flask 앱 "dashApp1"제공 (지연 로딩)

  • 환경 : 생산

    경고 : 프로덕션 환경에서 개발 서버를 사용하지 마십시오.

    대신 프로덕션 WSGI 서버를 사용하십시오.

  • 디버그 모드 : 켜기

  • stat로 다시 시작

  • 디버거가 활성화되었습니다!

  • 디버거 PIN : 130-303-947

  • 실행 중 http://127.0.0.1:8050/ (종료하려면 Ctrl + C를 누릅니다)

127.0.0.1 - - [12/Aug/2018 09:32:39] "GET / HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-layout HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /_dash-dependencies HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:32:42] "GET /favicon.ico HTTP/1.1" 200 -
127.0.0.1 - - [12/Aug/2018 09:39:52] "GET /favicon.ico HTTP/1.1" 200 -

방문 http:127.0.0.1:8050/웹 브라우저에서. 다음과 같은 앱이 표시되어야합니다.

위의 프로그램에서 주목해야 할 몇 가지 중요한 사항은 다음과 같습니다.

  • 앱 레이아웃은 html.Div 및 dcc.Graph와 같은 "구성 요소"트리로 구성됩니다.

  • dash_html_components 라이브러리에는 모든 HTML 태그에 대한 구성 요소가 있습니다. html.H1 (children = 'Hello Dash') 구성 요소는 애플리케이션에서 <h1> Hello Dash </ h1> HTML 요소를 생성합니다.

  • 모든 구성 요소가 순수한 HTML은 아닙니다. dash_core_components는 React.js 라이브러리를 통해 JavaScript, HTML 및 CSS로 생성되는 대화 형 고급 구성 요소를 설명합니다.

  • 각 구성 요소는 키워드 속성을 통해 완전히 설명됩니다. 대시는 선언적입니다. 주로 이러한 속성을 통해 애플리케이션을 설명합니다.

  • 어린이 속성은 특별합니다. 관례 상 항상 첫 번째 속성이므로 생략 할 수 있습니다.

  • Html.H1 (children = 'Hello Dash')은 html.H1 ( 'Hello Dash')과 동일합니다.

  • 응용 프로그램의 글꼴은 여기에 표시되는 글꼴과 약간 다릅니다. 이 애플리케이션은 사용자 정의 CSS 스타일 시트를 사용하여 요소의 기본 스타일을 수정합니다. 사용자 정의 글꼴 스타일이 허용되지만 지금은 아래 URL 또는 원하는 URL을 추가 할 수 있습니다.

    app.css.append_css ({“external_url”:https://codepen.io/chriddyp/pen/bwLwgP.css}) 파일이이 예제와 동일한 모양과 느낌을 갖도록합니다.

HTML에 대한 추가 정보

dash_html_components 라이브러리에는 모든 HTML 태그에 대한 구성 요소 클래스와 모든 HTML 인수에 대한 키워드 인수가 포함되어 있습니다.

이전 앱 텍스트에서 구성 요소의 인라인 스타일을 추가해 보겠습니다.

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()
colors = {
   'background': '#87D653',
   'text': '#ff0033'
}

app.layout = html.Div(style={'backgroundColor': colors['background']}, children=[
   html.H1(
      children='Hello Dash',
      style={
         'textAlign': 'center',
         'color': colors['text']
      }
   ),
	
   html.Div(children='Dash: A web application framework for Python.', style={
      'textAlign': 'center',
      'color': colors['text']
   }),
	
   dcc.Graph(
      id='example-graph-2',

      figure={
         'data': [
            {'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar', 'name': 'Delhi'},
            {'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar', 'name': u'Mumbai'},
         ],
         'layout': {
            'plot_bgcolor': colors['background'],
            'paper_bgcolor': colors['background'],
            'font': {
               'color': colors['text']
            }
         }
      }
   )
])

if __name__ == '__main__':
   app.run_server(debug=True)

위의 예에서는 style 속성을 사용하여 html.Div 및 html.H1 구성 요소의 인라인 스타일을 수정했습니다.

다음과 같이 대시 애플리케이션에서 렌더링됩니다.

dash_html_components와 HTML 속성 사이에는 몇 가지 주요 차이점이 있습니다.

  • Dash의 스타일 속성의 경우 사전 만 제공 할 수 있지만 HTML에서는 세미콜론으로 구분 된 문자열입니다.

  • 스타일 사전 키는 camelCased이므로 텍스트 정렬이 textalign.

  • Dash의 ClassName은 HTML 클래스 속성과 유사합니다.

  • 첫 번째 인수는 children 키워드 인수를 통해 지정된 HTML 태그의 하위입니다.

재사용 가능한 구성 요소

Python으로 마크 업을 작성하면 컨텍스트 나 언어를 전환하지 않고도 테이블과 같은 복잡한 재사용 가능한 구성 요소를 만들 수 있습니다.

다음은 pandas 데이터 프레임에서 "테이블"을 생성하는 빠른 예입니다.

import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd

df = pd.read_csv(
   'https://gist.githubusercontent.com/chriddyp/'
   'c78bf172206ce24f77d6363a2d754b59/raw/'
   'c353e8ef842413cae56ae3920b8fd78468aa4cb2/'
   'usa-agricultural-exports-2011.csv')
	
def generate_table(dataframe, max_rows=10):
   return html.Table(
      # Header
      [html.Tr([html.Th(col) for col in dataframe.columns])] +
      # Body
      [html.Tr([
         html.Td(dataframe.iloc[i][col]) for col in dataframe.columns
      ]) for i in range(min(len(dataframe), max_rows))]
   )
	
app = dash.Dash()
app.layout = html.Div(children=[
   html.H4(children='US Agriculture Exports (2011)'),
   generate_table(df)
])

if __name__ == '__main__':
   app.run_server(debug=True)

우리의 출력은 다음과 같습니다.

시각화에 대한 추가 정보

dash_core_components 라이브러리에는 Graph.

Graph는 오픈 소스 plotly.js JavaScript 그래프 라이브러리를 사용하여 대화 형 데이터 시각화를 렌더링합니다. Plotly.js는 약 35 개의 차트 유형을 지원하고 벡터 품질 SVG 및 고성능 WebGL로 차트를 렌더링합니다.

아래는 Pandas 데이터 프레임에서 산점도를 만드는 예입니다.

import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd
import plotly.graph_objs as go

app = dash.Dash()

df = pd.read_csv(
   'https://gist.githubusercontent.com/chriddyp/' +
   '5d1ea79569ed194d432e56108a04d188/raw/' +
   'a9f9e8076b837d541398e999dcbac2b2826a81f8/'+
   'gdp-life-exp-2007.csv')
	
app.layout = html.Div([
   dcc.Graph(
      id='life-exp-vs-gdp',
      figure={
         'data': [
            go.Scatter(
               x=df[df['continent'] == i]['gdp per capita'],
               y=df[df['continent'] == i]['life expectancy'],
               text=df[df['continent'] == i]['country'],
               mode='markers',
               opacity=0.7,
               marker={
                  'size': 15,
                  'line': {'width': 0.5, 'color': 'white'}
               },
               name=i
            ) for i in df.continent.unique()
         ],
         'layout': go.Layout(
            xaxis={'type': 'log', 'title': 'GDP Per Capita'},
            yaxis={'title': 'Life Expectancy'},
            margin={'l': 40, 'b': 40, 't': 10, 'r': 10},
            legend={'x': 0, 'y': 1},
            hovermode='closest'
         )
      }
   )
])

if __name__ == '__main__':
   app.run_server()

위 코드의 출력은 다음과 같습니다.

이러한 그래프는 대화 형이며 반응 형입니다. 포인트 위로 마우스를 가져가 해당 값을 확인하고, 범례 항목을 클릭하여 트레이스를 전환하고, 클릭하고 드래그하여 확대 / 축소하고, Shift 키를 누른 채 클릭하고 드래그하여 이동할 수 있습니다.

가격 인하

dash는 dash_html_components 라이브러리를 통해 HTML 풍미를 노출하지만 HTML로 사본을 작성하는 것은 지루할 수 있습니다. 텍스트 블록을 작성하기 위해 dash_core_components 라이브러리에서 Markdown 구성 요소를 사용할 수 있습니다.

핵심 구성 요소

dash_core_components에는 드롭 다운, 그래프, 마크 다운, 블록 등과 같은 상위 수준 구성 요소 집합이 포함됩니다.

다른 모든 Dash 구성 요소와 마찬가지로 완전히 선언적으로 설명됩니다. 구성 가능한 모든 옵션은 구성 요소의 키워드 인수로 사용할 수 있습니다.

다음은 사용 가능한 구성 요소 중 일부를 사용한 예입니다.

# -*- coding: utf-8 -*-
import dash
import dash_core_components as dcc
import dash_html_components as html

app = dash.Dash()

app.layout = html.Div([
   html.Label('Dropdown'),
   dcc.Dropdown(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value='MTL'
   ),
	
   html.Label('Multi-Select Dropdown'),
   dcc.Dropdown(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value=['MTL', 'SF'],
      multi=True
   ),
	
   html.Label('Radio Items'),
   dcc.RadioItems(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      value='MTL'
   ),
	
   html.Label('Checkboxes'),
   dcc.Checklist(
      options=[
         {'label': 'New York City', 'value': 'NYC'},
         {'label': u'Montréal', 'value': 'MTL'},
         {'label': 'San Francisco', 'value': 'SF'}
      ],
      values=['MTL', 'SF']
   ),

   html.Label('Text Input'),
   dcc.Input(value='MTL', type='text'),
	
   html.Label('Slider'),
   dcc.Slider(
      min=0,
      max=9,
      marks={i: 'Label {}'.format(i) if i == 1 else str(i) for i in range(1, 6)},
      value=5,
   ),
], style={'columnCount': 2})

if __name__ == '__main__':
   app.run_server(debug=True)

위 프로그램의 출력은 다음과 같습니다.

도움 요청

대시 구성 요소는 선언적입니다. 이러한 구성 요소의 모든 구성 가능한 측면은 설치 중에 키워드 인수로 설정됩니다. 모든 구성 요소의 Python 콘솔에서 도움말을 호출하여 구성 요소 및 사용 가능한 인수에 대해 자세히 알아볼 수 있습니다. 그들 중 일부는 아래에 주어진다-

>>> help(dcc.Dropdown)
Help on class Dropdown in module builtins:
class Dropdown(dash.development.base_component.Component)
| A Dropdown component.
| Dropdown is an interactive dropdown element for selecting one or more

| items.
| The values and labels of the dropdown items are specified in the `options`
| property and the selected item(s) are specified with the `value` property.
|
| Use a dropdown when you have many options (more than 5) or when you are
| constrained for space. Otherwise, you can use RadioItems or a Checklist,
| which have the benefit of showing the users all of the items at once.
|
| Keyword arguments:
| - id (string; optional)
| - options (list; optional): An array of options
| - value (string | list; optional): The value of the input. If `multi` is false (the default)
-- More --

요약하면 Dash 앱의 레이아웃은 앱의 모양을 설명합니다. 레이아웃은 구성 요소의 계층 구조 트리입니다. dash_html_components 라이브러리는 모든 HTML 태그 및 키워드 인수에 대한 클래스를 제공하고 style, className 및 id와 같은 HTML 속성을 설명합니다. dash_core_components 라이브러리는 컨트롤 및 그래프와 같은 상위 수준 구성 요소를 생성합니다.

Python 웹 프레임 워크의 세계는 다양한 선택을 제공합니다. 고려해야 할 눈에 띄는 프레임 워크 중 일부는 Django, Flask, Bottle, Diesel, Web2py, Pyramid, Falcon, Pecan 등이며 개발자의 마음을 공유하기 위해 경쟁합니다. Pyramid, Django, Web2py 및 Flask와 같은 프레임 워크는 장단점 목록에 이상적입니다. 프로젝트에 하나만 선택하는 것은 어려운 선택입니다.

Dash는 완전히 다양한 요구 사항을 위해 설계되었습니다. 따라서 개발자는 프로젝트를 제 시간에 완벽하게 완료하는 데 도움이되는 옵션으로 다양한 옵션을 줄이고 자합니다.

Flask, Pyramid 및 Django 프레임 워크를 비교하면 Flask는 주로 더 간단한 요구 사항을 가진 작은 애플리케이션을 겨냥한 마이크로 프레임 워크 인 반면 Pyramid와 Django는 모두 더 큰 애플리케이션을 목표로합니다. Pyramid는 유연성과 자유를 염두에두고 제작되었으므로 개발자는 프로젝트에 적합한 도구를 가지고 있습니다. 피라미드의 경우 개발자는 데이터베이스, URL 구조, 템플릿 스타일 등을 자유롭게 선택할 수 있습니다. 그러나 Django에는 웹 애플리케이션에 필요한 모든 배터리가 포함되어 있으므로 Django를 설치하고 작업을 시작하기 만하면됩니다.

Django는 ORM과 함께 제공되지만 Pyramid와 Flask는 데이터 저장 방법 (또는 경우)을 선택하도록 개발자에게 맡깁니다. 일반적으로 장고가 아닌 웹 응용 프로그램의 가장 일반적인 ORM은 지금까지 SQLAlchemy이지만 다른 옵션은 DjangoDB, MongoDB, LevelDB 및 SQLite 일 수 있습니다.

내 프로젝트를 위해 Django와 Web2py 중에서 선택해야하는 경우 개발자가됩니다. 프레임 워크의 장점과 한계에 대한 아이디어가 필요합니다. 그래서 Django와 Web2py를 비교해 봅시다.

장고

Django 커뮤니티는 큰 장점입니다. 이것은 실제로 개발자에게 풍부한 자원이 더 클 것이라는 것을 의미합니다. 구체적으로, 이것은-

  • Documentation
  • 오픈 소스 리소스
  • 타사 앱 지원
  • 배포 지원
  • 유용한 개발자가있는 IRC 채널

Django에는 개발 팀과 문서로 구성된 매우 큰 커뮤니티가 있습니다. 사용자 로직 (가입, 인증), 비동기 작업, API 생성, 블로그 등을 자동화 할 수있는 많은 타사 앱을 제공하므로 복잡한 백엔드 작성을 처리 할 때 적합한 프레임 워크입니다.

Web2py

Web2py는 간단한 웹 앱 또는 http 서버의 빠른 개발에 적합합니다. 다음은 web2py의 장점과 제한 사항 중 일부입니다.

Web2py의 이점

다음은 Web2py 프레임 워크의 이점 중 일부입니다.

  • Web2py는 개발의 속도와 단순성 측면에서 Django 및 Flask와 비교할 때 잠재적 인 프레임 워크입니다. Web2py는 Python 기반 템플릿 언어를 사용하므로 Python 개발자는 템플릿을 뷰로 작성하는 기본 사항을 이해 한 후 즉시 코드 작성을 시작할 수 있습니다.

  • Web2py는 실행 시간을 줄이고 컴파일 된 방식으로 코드를 배포 할 수 있도록 최적화로 Python 컴파일 코드를 실행할 수 있습니다.

Web2py의 한계

다음은 프레임 워크의 몇 가지 제한 사항입니다.

  • Web2py는 doctest를 지원하지만 단위 테스트는 지원하지 않습니다. 이제 doctest는 제한된 범위 때문에 최적의 선택이 아닙니다.

  • 프로덕션 모드와 개발 모드에는 차이가 없습니다. 예외가 발생하는 경우 항상 티켓이 생성되며 오류를 확인하기 위해 티켓으로 이동해야합니다. 이는 프로덕션 서버의 경우 유용 할 수 있지만 개발자가 티켓 번호를 확인하는 대신 즉시 오류를 확인해야하기 때문에 개발 환경에서는 어려울 수 있습니다.

  • Web2py에는 많은 유형의 데이터베이스 엔진을 추상화 할 수있는 좋은 데이터베이스 추상화 계층 (DAL)이 있지만 강력한 ORM이 없습니다. 비교적 큰 모델을 다루는 경우 코드는 모든 중첩 된 정의와 속성으로 흩어져 일을 복잡하게 만듭니다.

  • web2py는 IDE 지원이 정말 열악하기 때문에 수정없이 표준 파이썬 개발 도구를 사용할 수 없습니다.

Django 및 Web2py 프레임 워크는 풀 스택 프레임 워크입니다. 즉, 양식 생성기에서 템플릿 레이아웃 및 양식 유효성 검사에 이르기까지 필요한 모든 코드를 제공하고 특정 요구 사항에 따라 작성해야합니다.

그러나 Flask 및 Pyramid와 같은 비 스택 프레임 워크를 사용하여 완전한 기능을 갖춘 웹 사이트를 만들려면 많은 코드와 추가 비트를 직접 추가해야합니다. 이것은 많은 기술과 시간이 필요합니다.

대시

Dash는 대시 보드를위한 반응 형 프레임 워크를 구축하는 특정 작업을 위해 완전히 설계되었습니다. Dash by Plotly는 Python 개발자가 자바 스크립트 및 프런트 엔드 웹 개발을 배우지 않고도 대화 형 웹 앱을 만들 수있는 좋은 방법입니다. Dash는 Flask, Plotly.js, React 및 React Js를 기반으로 구축되었습니다.

Dash와 다른 프레임 워크 (위에서 언급)는 서로 다른 범주의 프레임 워크에 속하므로 비교가 없습니다. 다음은 다른 대화 형 대시 보드 프레임 워크 (Jupiter Dashboards, matplotlib 및 기타)보다 대시를 선호하는 몇 가지 이유입니다.

  • 50 줄의 코드만으로 간단한 "hello world"Dash 앱을 작성할 수 있습니다. Dash는 보일러 플래터가 거의 필요하지 않습니다.

  • 전체 대시 앱은 전 세계적으로 가장 선호되는 언어 인 Python 언어로 작성됩니다.

  • 자신의 Python 코드에서 드롭 다운, 텍스트 입력, 슬라이더 및 그래프와 같은 대시 대화 형 구성 요소를 반응 형 대시 "콜백"으로 바인딩 할 수 있습니다.

  • Dash 앱의 복잡한 UI에는 다른 입력에 의존하는 여러 입력, 여러 출력 및 입력이있을 수 있습니다.

  • 동시에 여러 사용자가 Dash 앱에서 작업 할 수 있습니다.

  • React로 자신 만의 Dash 구성 요소를 만들기 위해 dash는 React.js를 사용하여 구성 요소를 렌더링하고 플러그인 시스템을 포함합니다.

  • 개발자 또는 작성자는 Dash의 그래프 구성 요소가 대화 형이므로 그래프의 클릭, 호버링 또는 선택에 응답하는 대시 앱을 작성할 수 있습니다.

결론

사용 가능한 많은 파이썬 프레임 워크 중에서 올바른 프레임 워크를 선택하는 것은 전적으로 프로젝트 유형, 복잡성, 소규모 또는 엔터프라이즈 수준 프로젝트, 사용 가능한 커뮤니티 지원 또는 사용 가능한 온라인 리소스, 확장 성, 보안 등에 달려 있다고 결론을 내릴 수 있습니다.

위에서 언급 한 파이썬 프레임 워크는 동급 최고이지만 프로젝트 요구 사항에 따라 고유 한 장점과 단점이 있습니다. 따라서 한 가지 유형의 프레임 워크는 모든 종류의 프로젝트에 적합하지 않습니다.