Python Web Development
Python is a widely used high-level programming language for general-purpose programming, created by Guido van Rossum and first released in 1991. An interpreted language, Python has a design philosophy that emphasizes code readability (notably usingwhitespace indentation to delimit code blocks rather than curly brackets or keywords), and a syntax that allows programmers to express concepts in fewer lines of code than might be used in languages such as C++ or Java.[23][24] The language provides constructs intended to enable writing clear programs on both a small and large scale.
Python features a dynamic type system and automatic memory management and supports multiple programming paradigms, including object-oriented, imperative, functional programming, and procedural styles. It has a large and comprehensive standard library.
Python interpreters are available for many operating systems, allowing Python code to run on a wide variety of systems. CPython, thereference implementation of Python, is open source software[27] and has a community-based development model, as do nearly all of its variant implementations. CPython is managed by the non-profit Python Software Foundation.
The design of Python offers some support for functional programming in the Lisp tradition. The language has
Rather than requiring all desired functionality to be built into the language's core, Python was designed to be highly extensible. Python can also be embedded in existing applications that need a programmable interface. This design of a small core language with a large standard library and an easily extensible interpreter was intended by Van Rossum from the start because of his frustrations with ABC, which espoused the opposite mindset .
While offering choice in coding methodology, the Python philosophy rejects exuberant syntax, such as in Perl, in favor of a sparser, less-cluttered grammar. As Alex Martelli put it: "To describe something as clever is not considered a compliment in the Python culture."[47] Python's philosophy rejects the Perl "there is more than one way to do it" approach to language design in favor of "there should be one—and preferably only one—obvious way to do it".
Python's developers strive to avoid premature optimization, and moreover, reject patches to non-critical parts of CPython that would offer a marginal increase in speed at the cost of clarity.[48] When speed is important, a Python programmer can move time-critical functions to extension modules written in languages such as C, or try using PyPy, a just-in-time compiler. Cython is also available, which translates a Python script into C and makes direct C-level API calls into the Python interpreter.
An important goal of Python's developers is making it fun to use. This is reflected in the origin of the name, which comes from Monty Python,[49] and in an occasionally playful approach to tutorials and reference materials, such as using examples that refer to spam and eggs instead of the standard foo and bar.
Python features a dynamic type system and automatic memory management and supports multiple programming paradigms, including object-oriented, imperative, functional programming, and procedural styles. It has a large and comprehensive standard library.
Python interpreters are available for many operating systems, allowing Python code to run on a wide variety of systems. CPython, thereference implementation of Python, is open source software[27] and has a community-based development model, as do nearly all of its variant implementations. CPython is managed by the non-profit Python Software Foundation.
Python was conceived in the late 1980s,[28] and its implementation began in December 1989[29] by Guido van Rossum at Centrum Wiskunde & Informatica (CWI) in the Netherlands as a successor to the ABC language (itself inspired by SETL)[30] capable of exception handling and interfacing with the operating system Amoeba.[6] Van Rossum is Python's principal author, and his continuing central role in deciding the direction of Python is reflected in the title given to him by the Python community, Benevolent Dictator For Life (BDFL).
Over six years ago, in December 1989, I was looking for a "hobby" programming project that would keep me occupied during the week around Christmas. My office ... would be closed, but I had a home computer, and not much else on my hands. I decided to write an interpreter for the new scripting language I had been thinking about lately: a descendant ofABC that would appeal to Unix/C hackers. I chose Python as a working title for the project, being in a slightly irreverent mood (and a big fan of Monty Python's Flying Circus).
Python 2.0 was released on 16 October 2000 and had many major new features, including a cycle-detecting garbage collector and support for Unicode. With this release the development process was changed and became more transparent and community-backed.
Python 3.0 (that early in its development was commonly referred to as Python 3000 or py3k), a major, backward-incompatible release, was released on 3 December 2008[33] after a long period of testing. Many of its major features have been backported to the backwards-compatible Python 2.6.x[34] and 2.7.x version series.
The End Of Life date (EOL, sunset date) for Python 2.7 was initially set at 2015, then postponed to 2020 out of concern that a large body of existing code cannot easily be forward-ported to Python 3.[35][36] In January 2017, Google announced work on a Python 2.7 to Go transcompiler, which The Register speculated was in response to Python 2.7's planned end-of-life[37] but Google cited performance under concurrent workloads as their only motivation.
Python is a multi-paradigm programming language: object-oriented programming and structured programming are fully supported, and many language features support functional programming and aspect-oriented programming (including by metaprogramming[39] and metaobjects (magic methods)).[40] Many other paradigms are supported via extensions, including design by contract[41][42] and logic programming.
Python uses dynamic typing and a mix of reference counting and a cycle-detecting garbage collector for memory management. An important feature of Python is dynamic name resolution (late binding), which binds method and variable names during program execution.
The design of Python offers some support for functional programming in the Lisp tradition. The language has
filter()
, map()
, and reduce()
functions; list comprehensions, dictionaries, and sets; and generator expressions.[44] The standard library has two modules (itertools and functools) that implement functional tools borrowed from Haskell and Standard ML.
The core philosophy of the language is summarized by the document The Zen of Python (PEP 20), which includes aphorisms such as:[46]
- Beautiful is better than ugly
- Explicit is better than implicit
- Simple is better than complex
- Complex is better than complicated
- Readability counts
Rather than requiring all desired functionality to be built into the language's core, Python was designed to be highly extensible. Python can also be embedded in existing applications that need a programmable interface. This design of a small core language with a large standard library and an easily extensible interpreter was intended by Van Rossum from the start because of his frustrations with ABC, which espoused the opposite mindset .
While offering choice in coding methodology, the Python philosophy rejects exuberant syntax, such as in Perl, in favor of a sparser, less-cluttered grammar. As Alex Martelli put it: "To describe something as clever is not considered a compliment in the Python culture."[47] Python's philosophy rejects the Perl "there is more than one way to do it" approach to language design in favor of "there should be one—and preferably only one—obvious way to do it".
Python's developers strive to avoid premature optimization, and moreover, reject patches to non-critical parts of CPython that would offer a marginal increase in speed at the cost of clarity.[48] When speed is important, a Python programmer can move time-critical functions to extension modules written in languages such as C, or try using PyPy, a just-in-time compiler. Cython is also available, which translates a Python script into C and makes direct C-level API calls into the Python interpreter.
An important goal of Python's developers is making it fun to use. This is reflected in the origin of the name, which comes from Monty Python,[49] and in an occasionally playful approach to tutorials and reference materials, such as using examples that refer to spam and eggs instead of the standard foo and bar.
A common neologism in the Python community is pythonic, which can have a wide range of meanings related to program style. To say that code is pythonic is to say that it uses Python idioms well, that it is natural or shows fluency in the language, that it conforms with Python's minimalist philosophy and emphasis on readability. In contrast, code that is difficult to understand or reads like a rough transcription from another programming language is called unpythonic.
Users and admirers of Python, especially those considered knowledgeable or experienced, are often referred to as Pythonists, Pythonistas, and Pythoneers.
Python is intended to be a highly readable language. It is designed to have an uncluttered visual layout, often using English keywords where other languages use punctuation. Python does not use curly brackets to delimit blocks, and semicolons after statements are optional, in contrast to many other programming languages. Further, Python has fewer syntactic exceptions and special cases than C or Pascal.
Python uses whitespace indentation to delimit blocks – rather than curly braces or keywords. An increase in indentation comes after certain statements; a decrease in indentation signifies the end of the current block.[55] This feature is also sometimes termed the off-side rule.
- The assignment statement (token '=', the equals sign). This operates differently than in traditional imperative programming languages, and this fundamental mechanism (including the nature of Python's version of variables) illuminates many other features of the language. Assignment in C, e.g.,
x = 2
, translates to "typed variable name x receives a copy of numeric value 2". The (right-hand) value is copied into an allocated storage location for which the (left-hand) variable name is the symbolic address. The memory allocated to the variable is large enough (potentially quite large) for the declared type. In the simplest case of Python assignment, using the same example,x = 2
, translates to "(generic) name x receives a reference to a separate, dynamically allocated object of numeric (int) type of value 2." This is termed binding the name to the object. Since the name's storage location doesn't contain the indicated value, it is improper to call it a variable. Names may be subsequently rebound at any time to objects of greatly varying types, including strings, procedures, complex objects with data and methods, etc. Successive assignments of a common value to multiple names, e.g.,x = 2
;y = 2
;z = 2
result in allocating storage to (at most) three names and one numeric object, to which all three names are bound. Since a name is a generic reference holder it is unreasonable to associate a fixed data type with it. However at a given time a name will be bound to some object, which will have a type; thus there is dynamic typing. - The
if
statement, which conditionally executes a block of code, along withelse
andelif
(a contraction of else-if).
- The
for
statement, which iterates over an iterable object, capturing each element to a local variable for use by the attached block. - The
while
statement, which executes a block of code as long as its condition is true. - The
try
statement, which allows exceptions raised in its attached code block to be caught and handled byexcept
clauses; it also ensures that clean-up code in afinally
block will always be run regardless of how the block exits. - The
class
statement, which executes a block of code and attaches its local namespace to a class, for use in object-oriented programming. - The
def
statement, which defines a function or method. - The
with
statement (from Python 2.5), which encloses a code block within a context manager (for example, acquiring a lock before the block of code is run and releasing the lock afterwards, or opening a file and then closing it), allowing Resource Acquisition Is Initialization (RAII)-like behavior. - The
pass
statement, which serves as a NOP. It is syntactically needed to create an empty code block. - The
assert
statement, used during debugging to check for conditions that ought to apply. - The
yield
statement, which returns a value from a generator function. From Python 2.5,yield
is also an operator. This form is used to implement coroutines. - The
import
statement, which is used to import modules whose functions or variables can be used in the current program.There are two ways of using import . from <module name> import * or import <module name>. - The
print
statement was changed to theprint()
function in Python 3. - Python does not support tail call optimization or first-class continuations, and, according to Guido van Rossum, it never will.[57][58] However, better support for coroutine-like functionality is provided in 2.5, by extending Python's generators.[59] Before 2.5, generators were lazy iterators; information was passed unidirectionally out of the generator. From Python 2.5, it is possible to pass information back into a generator function, and from Python 3.3, the information can be passed through multiple stack levels.
Expressions[edit]
- Addition, subtraction, and multiplication are the same, but the behavior of division differs. Python also added the
**
operator for exponentiation. - From Python 3.5, it enables support of matrix multiplication with the
@
operator.[61][62] - In Python,
==
compares by value, versus Java, which compares numerics by value[63] and objects by reference.[64] (Value comparisons in Java on objects can be performed with theequals()
method.) Python'sis
operator may be used to compare object identities (comparison by reference). In Python, comparisons may be chained, for examplea <= b <= c
. - Python uses the words
and
,or
,not
for its boolean operators rather than the symbolic&&
,||
,!
used in Java and C. - Python has a type of expression termed a list comprehension. Python 2.4 extended list comprehensions into a more general expression termed a generator expression.[44]
- Anonymous functions are implemented using lambda expressions; however, these are limited in that the body can only be one expression.
- Conditional expressions in Python are written as
x if c else y
[65] (different in order of operands from thec ? x : y
operator common to many other languages). - Python makes a distinction between lists and tuples. Lists are written as
[1, 2, 3]
, are mutable, and cannot be used as the keys of dictionaries (dictionary keys must beimmutable in Python). Tuples are written as(1, 2, 3)
, are immutable and thus can be used as the keys of dictionaries, provided all elements of the tuple are immutable. But values can be appended to the tuple using __add__(<another tuple>) . We can join two tuples . Indirectly we can add values to tuples . The parentheses around the tuple are optional in some contexts. Tuples can appear on the left side of an equal sign; hence a statement likex, y = y, x
can be used to swap two variables. - Python has a "string format" operator
%
. This functions analogous toprintf
format strings in C, e.g."spam=%s eggs=%d" % ("blah", 2)
evaluates to"spam=blah eggs=2"
. In Python 3 and 2.6+, this was supplemented by theformat()
method of thestr
class, e.g."spam={0} eggs={1}".format("blah", 2)
, Python 3.6 added "f-strings":f'spam={"blah"} eggs={2}'
.[66] - Python has various kinds of string literals:
- Strings delimited by single or double quote marks. Unlike in Unix shells, Perl and Perl-influenced languages, single quote marks and double quote marks function identically. Both kinds of string use the backslash (
\
) as an escape character. String interpolation became available in Python 3.6 as "formatted string literals".[66] - Triple-quoted strings, which begin and end with a series of three single or double quote marks. They may span multiple lines and function like here documents in shells, Perl and Ruby.
- Raw string varieties, denoted by prefixing the string literal with an
r
. Escape sequences are not interpreted; hence raw strings are useful where literal backslashes are common, such as regular expressions and Windows-style paths. Compare "@
-quoting" in C#.
- Strings delimited by single or double quote marks. Unlike in Unix shells, Perl and Perl-influenced languages, single quote marks and double quote marks function identically. Both kinds of string use the backslash (
- Python has array index and array slicing expressions on lists, denoted as
a[key]
,a[start:stop]
ora[start:stop:step]
. Indexes are zero-based, and negative indexes are relative to the end. Slices take elements from the start index up to, but not including, the stop index. The third slice parameter, called step or stride, allows elements to be skipped and reversed. Slice indexes may be omitted, for examplea[:]
returns a copy of the entire list. Each element of a slice is a shallow copy.
In Python, a distinction between expressions and statements is rigidly enforced, in contrast to languages such as Common Lisp, Scheme, or Ruby. This leads to duplicating some functionality. For example:
- List comprehensions vs.
for
-loops - Conditional expressions vs.
if
blocks - The
eval()
vs.exec()
built-in functions (in Python 2,exec
is a statement); the former is for expressions, the latter is for statements.
Statements cannot be a part of an expression, so list and other comprehensions or lambda expressions, all being expressions, cannot contain statements. A particular case of this is that an assignment statement such as
a = 1
cannot form part of the conditional expression of a conditional statement. This has the advantage of avoiding a classic C error of mistaking an assignment operator =
for an equality operator ==
in conditions: if (c = 1) { ... }
is syntactically valid (but probably unintended) C code but if c = 1: ...
causes a syntax error in Python.
Methods on objects are functions attached to the object's class; the syntax
instance.method(argument)
is, for normal methods and functions, syntactic sugar forClass.method(instance, argument)
. Python methods have an explicit self
parameter to access instance data, in contrast to the implicit self
(or this
) in some other object-oriented programming languages (e.g., C++, Java, Objective-C, or Ruby).
Python uses duck typing and has typed objects but untyped variable names. Type constraints are not checked at compile time; rather, operations on an object may fail, signifying that the given object is not of a suitable type. Despite being dynamically typed, Python is strongly typed, forbidding operations that are not well-defined (for example, adding a number to a string) rather than silently attempting to make sense of them.
Python allows programmers to define their own types using classes, which are most often used for object-oriented programming. New instances of classes are constructed by calling the class (for example,
SpamClass()
or EggsClass()
), and the classes are instances of the metaclass type
(itself an instance of itself), allowing metaprogrammingand reflection.
Before version 3.0, Python had two kinds of classes: old-style and new-style.[68] The syntax of both styles is the same, the difference being whether the class
object
is inherited from, directly or indirectly (all new-style classes inherit from object
and are instances of type
). In versions of Python 2 from Python 2.2 onwards, both kinds of classes can be used. Old-style classes were eliminated in Python 3.0.
The long term plan is to support gradual typing[69] and from Python 3.5, the syntax of the language allows specifying static types but they are not checked in the default implementation, CPython. An experimental optional static type checker named mypy supports compile-time type checking.
Python has the usual C arithmetic operators (
Python has the usual C arithmetic operators (
+
, -
, *
, /
, %
). It also has **
for exponentiation, e.g. 5**3 == 125
and 9**0.5 == 3.0
, and a new matrix multiply @
operator is included in version 3.5.[72] Additionally, it has a unary operator (~
), which essentially inverts all the bytes of its one argument. For integers, this means ~x=-x-1
.[73]Other operators include bitwise shift operators x << y
, which shifts x
to the left y
places, the same as x*(2**y)
, and x >> y
, which shifts x
to the right y
places, the same as x/(2**y).
The behavior of division has changed significantly over time:[75]
- Python 2.1 and earlier use the C division behavior. The
/
operator is integer division if both operands are integers, and floating-point division otherwise. Integer division rounds towards 0, e.g.7/3 == 2
and-7/3 == -2
. - Python 2.2 changes integer division to round towards negative infinity, e.g.
7/3 == 2
and-7/3 == -3
. The floor division//
operator is introduced. So7//3 == 2
,-7//3 == -3
,7.5//3 == 2.0
and-7.5//3 == -3.0
. Addingfrom __future__ import division
causes a module to use Python 3.0 rules for division (see next). - Python 3.0 changes
/
to be always floating-point division. In Python terms, the pre-3.0/
is classic division, the version-3.0/
is real division, and//
is floor division.
Rounding towards negative infinity, though different from most languages, adds consistency. For instance, it means that the equation
(a + b)//b == a//b + 1
is always true. It also means that the equation b*(a//b) + a%b == a
is valid for both positive and negative values of a
. However, maintaining the validity of this equation means that while the result of a%b
is, as expected, in the half-open interval [0, b), where b
is a positive integer, it has to lie in the interval (b, 0] when b
is negative.[76]
Python provides a
round
function for rounding a float to the nearest integer. For tie-breaking, versions before 3 use round-away-from-zero: round(0.5)
is 1.0,round(-0.5)
is −1.0.[77] Python 3 uses round to even: round(1.5)
is 2, round(2.5)
is 2.[78]
Python allows boolean expressions with multiple equality relations in a manner that is consistent with general use in mathematics. For example, the expression
a < b < c
tests whether a
is less than b
and b
is less than c
. C-derived languages interpret this expression differently: in C, the expression would first evaluate a < b
, resulting in 0 or 1, and that result would then be compared with c
.[79][page needed]
Python has extensive built-in support for arbitrary precision arithmetic. Integers are transparently switched from the machine-supported maximum fixed-precision (usually 32 or 64 bits), belonging to the python type
int
, to arbitrary precision, belonging to the python type long
, where needed. The latter have an "L" suffix in their textual representation.[80](In Python 3, the distinction between the int
and long
types was eliminated; this behavior is now entirely contained by the int
class.) The Decimal
type/class in moduledecimal
(since version 2.4) provides decimal floating point numbers to arbitrary precision and several rounding modes.[81] The Fraction
type in module fractions
(since version 2.6) provides arbitrary precision for rational numbers.[82]
Due to Python's extensive mathematics library, and the third-party library NumPy that further extends the native capabilities, it is frequently used as a scientific scripting language to aid in problems such as numerical data processing and manipulation.
Comments
Post a Comment