motivație, sugestii, exemple
diferențe față de PEP 8
pylint, pep8, flake8
{"indentare": (4, "spații"), "lugime_linie": 79}
{"clasa": "ClasaMea", "functie": "functia_mea"}
# Biblioteci standard
import os
import sys
from subprocess import Popen, PIPE
# Biblioteci externe
from jarvis.worker import Daemon
# Biblioteci locale
import proiect.procesator as procesator
from .procesator import procesator as procesator2
# Putem sa folosim identarea pentru a evidenția conținutul
matrice = [
1, 2, 3, 4,
5, 6, 7, 8]
alta_matrice = [1, 2, 3, 4,
5, 6, 7, 8]
# Adăugăm încă un nivel de indentare pentru a nu se confunda cu corpul
# funcției.
def long_function_name(
variabila_unu, variabila_doi, variabila_trei,
variabila_patru):
print(variabila_unu)
# Adaugăm indentare pentru a continua pe linie nouă
foo = long_function_name(
var_one, variabila_doi,
variabila_trei, variabila_patru)
# Aliniem argumentele de pe al doilea rând sub primul argument
functie_cu_multe_argumente("RoPython", eveniment="Workshop #1", locatie="UAIC",
durata=7200, participanti=50)
"""Nu se pun spații după paranteze sau acolade"""
# Greșit
oferă("premii", { "bilete_ropython": 5, "tricouri": 0 } )
# Corect
oferă("premii", {"bilete_ropython": 5, "tricouri": 0})
"""Nu se pun spații înainte de virgulă"""
# Greșit
if raspuns == "ropython": print participant , premiu
# Corect
if raspuns == "ropython": print participant, premiu
"""Nu se pune spațiu după numele unui obiect"""
# Greșit
ropython ['participanți'] = informatii [index]
# Corect
ropython['participanți'] = informatii[index]
"""Nu se adaugă spații inutile pentru alinierea valorilor"""
# Greșit
var_a = 10
var_b = 11
acceleratie = 20
# Corect
var_a = 10
var_b = 11
acceleratie = 20
"""
folosim _ pentru a marca elementele ce interne
"""
# Nume de clasa
class NumeClasa(object):
__atribut = 10
# __lower_case__ - obiect "magic"
def __init__(self):
pass
# Clasa pentru uz intern în modul
class _NumeClasa(object):
pass
"""Se recomandă evitarea formularilor vechi"""
# Varianta recomandată
try:
# Ceva cod interesant aici
except ValueError as exc:
raise ValueError("Operație imposibilă !")
# Varianta greșită
try:
# Ceva cod interesant aici
except ValueError, exc:
raise ValueError "Operație imposibilă !"
# Dezastruos
try:
# Ceva cod interesant aici
except:
pass
"""Greșeli comune"""
# Recomandat
if foo.startswith('bar'): pass
# Nerecomandat - Poate cauza probleme
if foo[:3] == 'bar': pass
# Practica cea mai eleganta
if isinstance(obj, int): pass
# Nerecomandat
if type(obj) is type(1): pass
# Ok
if ceva is None: pass
if not ceva: pass
if ceva: pass
# Greșit
if ceva == True: pass
# Foarte greșit
if ceva is True: pass # Și ceva poate fi doar `True` sau `False`
if ceva == None: pass
Type | Public | Internal |
---|---|---|
Packages | lower_with_under | |
Modules | lower_with_under | _lower_with_under |
Classes | CapWords | _CapWords |
Exceptions | CapWords | |
Functions | lower_with_under() | _lower_with_under() |
Global/Class Constants | CAPS_WITH_UNDER | _CAPS_WITH_UNDER |
Type | Public | Internal |
---|---|---|
Global/Class Variables | lower_with_under | _lower_with_under |
Instance Variables | lower_with_under | _lower_with_under __lower_with_under |
Method Names | lower_with_under() | _lower_with_under() __lower_with_under() |
Function/Method Parameters | lower_with_under | |
Local/Variables | lower_with_under |
W: 5, 0: Bad indentation. Found 3 spaces, expected 4 (bad-indentation)
W: 8, 0: Bad indentation. Found 3 spaces, expected 4 (bad-indentation)
W: 9, 0: Bad indentation. Found 3 spaces, expected 4 (bad-indentation)
W: 10, 0: Bad indentation. Found 3 spaces, expected 4 (bad-indentation)
W: 11, 0: Bad indentation. Found 7 spaces, expected 8 (bad-indentation)
W: 12, 0: Bad indentation. Found 3 spaces, expected 4 (bad-indentation)
C: 13, 0: Trailing whitespace (trailing-whitespace)
W: 31, 0: Bad indentation. Found 7 spaces, expected 8 (bad-indentation)
W: 7, 0: Redefining built-in 'dir' (redefined-builtin)
C: 1, 0: Missing module docstring (missing-docstring)
C: 4, 0: Missing class docstring (missing-docstring)
W: 4, 0: Class has no __init__ method (no-init)
R: 4, 0: Too few public methods (0/2) (too-few-public-methods)
C: 7, 0: Missing function docstring (missing-docstring)
W: 15, 3: Unreachable code (unreachable)
W: 12,10: Using possibly undefined loop variable 'file' (undefined-loop-variable)
W: 7,14: Unused argument 'dirs' (unused-argument)
C: 17, 0: Missing function docstring (missing-docstring)
E: 20,10: Catching an exception which doesn't inherit from BaseException: SomeError (catching-non-exception)
C: 26, 0: Missing class docstring (missing-docstring)
$ flake8 coolproject
coolproject/mod.py:97:1: F401 'shutil' imported but unused
coolproject/mod.py:625:17: E225 missing whitespace around operato
coolproject/mod.py:729:1: F811 redefinition of function 'readlines' from line 723
coolproject/mod.py:1028:1: F841 local variable 'errors' is assigned to but never used
$ flake8 --max-complexity 12 coolproject
coolproject/mod.py:97:1: F401 'shutil' imported but unused
coolproject/mod.py:625:17: E225 missing whitespace around operator
coolproject/mod.py:729:1: F811 redefinition of unused 'readlines' from line 723
coolproject/mod.py:939:1: C901 'Checker.check_all' is too complex (12)
coolproject/mod.py:1028:1: F841 local variable 'errors' is assigned to but never used
coolproject/mod.py:1204:1: C901 'selftest' is too complex (14)