/flask-start-onefile

Start Python3 Flask one-file application

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

Flask Start OneFile (fork)

Tento repositář má vám i mně usnadnit založení nového projektu pro framework Flask. Zde najdete základní adresářovou strukturu pro aplikaci a kostru aplikace.

Pokud je aplikace složitější a místo jednoho souboru chce balíček, mrkněte se na Flask Start

... jak na to?

Dejme tomu že začínám nový projekt. Bude se jmenovat třeba Foo. Můžete si repositář forknout nebo naklonovat ale nejlepší je použít šablonu -- tím se vytvoří váš vlastní repositář s novou historií a ten si naklonujete.

Repositář obsahuje skript start.sh, který vše další udělá za vás.

  • vytvoří virtuální prostředí
  • nainstaluje potřebné balíčky
  • přestane sledovat .env
  • smaže sám sebe

Pokud chcete mít kontrolu, můžete pokračovat a všechno si pěkně udělat růčo.

VSCode

V souboru settings.json je nastavení, které vám zajistí očekávané chování VSCode.

{
  "files.associations": {
    "*.html": "jinja-html"
  },
  "emmet.includeLanguages": {
    "jinja-html": "html",
    "vue-html": "html"
  }

Doporučuji ještě doinstalovat si následující rozšíření:

LiveReload

LiveReload je udělátko, které slouží k automatickému znovu-načtení webové stránky při vývoji webových aplikací.

Jak si rozjet Live Reload

  1. Nainstalujete si rozšíření do prohlížeče
  2. Nainstalujete si rozšíření do VSCode
  3. Ve VSCode přes Ctrl+Shift+P spustíte Liver Reload nebo si v nastavení zapnete, aby se spuštělo samo při startu VSCode
  4. V prohlížeči kliknete na ikonku, aby se provedlo spojení VSCode a prohlížeče.

A je to!

Databáze

V souboru db.py naleznete context managery pro SQLite a MySQL i s příkladem použití.

>>> Pro MySQL doporučuji vyplnit defaultní nastavení podle potřeby projektu. <<<

MySQL Backup & Restore

Zálohování databáze do souboru db_backup.sql v aktuální adresáři.

mysqldump -u USERNAME -h HOST --set-gtid-purged=OFF --no-tablespaces --column-statistics=0 'DB_NAME' > db_backup.sql

Obnovení databáze ze souboru db_backup.sql v aktuální adresáři.

mysql -u USERNAME -h HOST 'DB_NAME' < db_backup.sql

USERNAME, HOST a DB_NAME musíte doplnit.

Příklad pro PythonAnywhere:

mysqldump -u mdolezel -h mdolezel.mysql.pythonanywhere-services.com --set-gtid-purged=OFF --no-tablespaces --column-statistics=0 'mdolezel$default' > db_backup.sql

mysql -u mdolezel -h mdolezel.mysql.pythonanywhere-services.com 'mdolezel$default' < db_backup.sql

Několik užitečných odkazů pro začátek





...

  1. Vytvořím si virtuální prostředí právě pro aplikaci Foo.:
python3 -m venv .venv-foo
  1. Virtuální prostředí si aktivuji:
source .venv-foo/bin/activate

nebo na Windows:

.venv-foo\Scripts\activate

  1. Do virtuálního prostředí nainstaluji potřebné moduly:
pip install -r requirements.txt

nebo ručně nestručně:

pip install flask flask-socketio
pip install flask-mail flask-misaka
pip install psycopg2 pony
  1. A teď stačí spustit vývojový server:
flask run