No description
Find a file
2023-03-02 22:10:01 +01:00
.github Merge pull request #5005 from pallets/dependabot/github_actions/slsa-framework/slsa-github-generator-1.5.0 2023-03-01 09:04:40 -08:00
artwork fix list numbering 2021-10-01 19:46:54 -07:00
docs deprecate markupsafe exports 2023-02-23 08:55:01 -08:00
examples Merge branch '2.2.x' 2023-02-23 15:58:29 -08:00
requirements update dependencies 2023-02-23 15:58:21 -08:00
src/flask add text parameter to config.from_file 2023-02-23 11:10:21 -08:00
tests add text parameter to config.from_file 2023-02-23 11:10:21 -08:00
.editorconfig add EditorConfig 2020-05-23 13:25:06 -07:00
.flake8 stop ignoring flake8 e402 2023-01-19 06:35:15 -08:00
.gitignore remove references to mailing list 2022-05-10 09:28:43 -07:00
.pre-commit-config.yaml Merge branch '2.2.x' 2023-02-23 15:58:29 -08:00
.readthedocs.yaml pin os and python version in rtd build 2021-12-22 20:06:08 -07:00
CHANGES.rst add text parameter to config.from_file 2023-02-23 11:10:21 -08:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2019-05-06 12:41:01 -04:00
CONTRIBUTING.rst update docs and examples for pyproject 2023-01-18 10:32:51 -08:00
LICENSE.rst standardize license and copyright 2019-06-22 13:09:09 -07:00
MANIFEST.in Initial typing support 2021-04-26 17:20:24 +01:00
pyproject.toml switch to pyproject.toml 2023-01-18 10:32:51 -08:00
README.rst Edited readme installation of flask to Windows and Mac OS's 2023-03-02 22:10:01 +01:00
tox.ini update tested python versions 2023-01-09 10:37:59 -08:00

Flask
=====

Flask is a lightweight `WSGI`_ web application framework. It is designed
to make getting started quick and easy, with the ability to scale up to
complex applications. It began as a simple wrapper around `Werkzeug`_
and `Jinja`_ and has become one of the most popular Python web
application frameworks.

Flask offers suggestions, but doesn't enforce any dependencies or
project layout. It is up to the developer to choose the tools and
libraries they want to use. There are many extensions provided by the
community that make adding new functionality easy.

.. _WSGI: https://wsgi.readthedocs.io/
.. _Werkzeug: https://werkzeug.palletsprojects.com/
.. _Jinja: https://jinja.palletsprojects.com/


Installation
------------
Python Version: ensure you are using the latest version of Python. Flask supports Python 3.7 and newer.

Create virtual environments:

Use a virtual environment to manage the dependencies for your project, both in development and in production.

What problem does a virtual environment solve? The more Python projects you have, the more likely it is that you need to work with different versions of Python libraries, or even Python itself. 
Newer versions of libraries for one project can break compatibility in another project.

MacOS:
.. code-block:: text

    mkdir myproject
    $ cd myproject
    $ python3 -m venv venv

Windows:
.. code-block:: text

    > mkdir myproject
    > cd myproject
    > py -3 -m venv venv

Activate virtual environments
MacOS:

.. code-block:: text

    $ . venv/bin/activate

Windows:

.. code-block:: text

    > venv\Scripts\activate


Install Flask
Within the activated environment, use the following command to install Flask and update using `pip`_:

.. code-block:: text

    $ pip install -U Flask

.. _pip: https://pip.pypa.io/en/stable/getting-started/


A Simple Example
----------------

.. code-block:: python

    # save this as app.py
    from flask import Flask

    app = Flask(__name__)

    @app.route("/")
    def hello():
        return "Hello, World!"

.. code-block:: text

    $ flask run
      * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)


Contributing
------------

For guidance on setting up a development environment and how to make a
contribution to Flask, see the `contributing guidelines`_.

.. _contributing guidelines: https://github.com/pallets/flask/blob/main/CONTRIBUTING.rst


Donate
------

The Pallets organization develops and supports Flask and the libraries
it uses. In order to grow the community of contributors and users, and
allow the maintainers to devote more time to the projects, `please
donate today`_.

.. _please donate today: https://palletsprojects.com/donate


Links
-----

-   Documentation: https://flask.palletsprojects.com/
-   Changes: https://flask.palletsprojects.com/changes/
-   PyPI Releases: https://pypi.org/project/Flask/
-   Source Code: https://github.com/pallets/flask/
-   Issue Tracker: https://github.com/pallets/flask/issues/
-   Website: https://palletsprojects.com/p/flask/
-   Twitter: https://twitter.com/PalletsTeam
-   Chat: https://discord.gg/pallets