-
Notifications
You must be signed in to change notification settings - Fork 10
Python
Not reinventing the excellent work that has already been put forth by the Python development community, nor seeking create our own style for Python code, we adopt the community developed PEP 8 - Style Guide for Python Code.
The guidance contained herein is provided to bring consistency to our processes, tools and practices when creating Python code for learning and use case development.
While specific instances and use cases may require the use of Python v2, and therefore should certainly do so, all other uses and all new development should default to using Python v3 (testing against the latest releases is recommended).
We follow the PEP8 style guide, and the following points are to be highlighted and considered mandatory (like we could make you do anything...):
- Indentation - 4 spaces
- Comments & Documentation Strings
- See the examples
- When describing what a script, module, function, class and etc. does - use Python's built-in Documentation Strings rather than block or inline comments.
- Naming Conventions
"Beautiful is better than ugly."
These practices (and the rest of the PEP8 style recommendations) net-out in an improved user experience for all those who read, modify and troubleshoot the code we publish.
To make writing PEP8-clean code easier, we recommend that you use an IDE or editor that provides real-time Python linting. It is easier to write clean code as you are writing it rather than having to come back and clean up linting errors later.
Recommended Linter: flake8
Many IDEs can leverage a user supplied linter, in these cases we recommend and use flake8. You can also use it as a command line tool to check your code before posting.
Installation:
$ pip install flake8
$ flake8 <your-script-or-code-directory>
Need | Tool |
---|---|
Python Interpreter | CPython |
Editor / IDE | IDLE |
Environment / Package Management | virtualenv |
Shell / Script Execution | BASH |
Debugging | Python Stack Traces, print() Statements, Interactive Interpreter |
COPYRIGHT © 2019-2021 CISCO SYSTEMS, INC. ALL RIGHTS RESERVED.