Advik Report On Python
Advik Report On Python
Our belief in the values of trust, transparency, flexibility and value-centricity, fuelled by our
philosophy of 'Employees First', ensures the continued pursuit of our customers' best
interests.
Unique and creative solutions that meet the clients’ expectations not only by realizing the
clients’ business objectives, but particularly by our strict adherence to the ethical principles of
Software Development and Web portal Development.
Professional quality of services and on time delivering the product provided by a highly
motivated and experienced team.
1
OBJECTIVE:
We aim at providing highest quality of service in every phase of Client Relationship from
initial contact to follow up support. Recognizing a client's needs and consistently exceeding
their expectations is what sets us apart from the rest. We therefore focus not only on
developing and maintaining the products and services we offer, but also on building long
term relationships.
2
INTRODUCTION
Python was conceived in the late 1980s as a successor to the ABC language. Python 2.0,
released 2000, introduced features like list comprehensions and a garbage collection system
capable of collecting reference cycles. Python 3.0, released 2008, was a major revision of the
language that is not completely backward-compatible, and much Python 2 code does not run
unmodified on Python 3. Due to concern about the amount of code written for Python 2,
support for Python 2.7 (the last release in the 2.x series) was extended to 2020. Language
developer Guido van Rossum shouldered sole responsibility for the project until July 2018
but now shares his leadership as a member of a five-person steering council.
The Python 2 language, i.e. Python 2.7.x, is "sunsetting" on January 1, 2020, and the Python
team of volunteers will not fix security issues, or improve it in other ways after that
date. With the end-of-life, only Python 3.6.x and later will be supported.
Python interpreters are available for many operating systems. A global community of
programmers develops and maintains CPython, an open source reference implementation.
A non-profit organization, the Python Software Foundation, manages and directs resources
for Python and CPython
3
History
Python was conceived in the late 1980s by Guido van Rossum at Centrum Wiskunde &
Informatica (CWI) in the Netherlands as a successor to the ABC language (itself inspired
by SETL), capable of exception handling and interfacing with the Amoeba operating system.
[8]
Its implementation began in December 1989.[38] Van Rossum continued as Python's lead
developer until July 12, 2018, when he announced his "permanent vacation" from his
responsibilities as Python's Benevolent Dictator For Life, a title the Python community
bestowed upon him to reflect his long-term commitment as the project's chief decision-
maker. In January, 2019, active Python core developers elected Brett Cannon, Nick Coghlan,
Barry Warsaw, Carol Willing and Van Rossum to a five-member "Steering Council" to lead
the project.
Python 2.0 was released on 16 October 2000 with many major new features, including
a cycle-detecting garbage collector and support for Unicode.
Python 3.0 was released on 3 December2008. It was a major revision of the language that is
not completely backward-compatible. Many of its major features were backported to Python
2.6.x[43] and 2.7.x version series. Releases of Python 3 include the 2to3 utility, which
automates (at least partially) the translation of Python 2 code to Python 3.
Python 2.7's end-of-life date was initially set at 2015 then postponed to 2020 out of concern
that a large body of existing code could not easily be forward-ported to Python 3. In January
2017, Google announced work on a Python 2.7 to Go transcompiler to improve performance
under concurrent workloads.
4
Features and philosophy
Python uses dynamic typing, and a combination of reference counting and a cycle-detecting
garbage collector for memory management. It also features dynamic name resolution (late
binding), which binds method and variable names during program execution.
Python's design offers some support for functional programming in the Lisp tradition. It
has filter , map, and reduce functions; list comprehensions, dictionaries, sets
and generator expressions. The standard library has two modules (itertools and functools) that
implement functional tools borrowed from Haskell and Standard ML.
The language's core philosophy is summarized in the document The Zen of Python (PEP 20),
which includes aphorisms such as:
Readability counts.
Rather than having all of its functionality built into its core, Python was designed to be
highly extensible. This compact modularity has made it particularly popular as a means of
adding programmable interfaces to existing applications. Van Rossum's vision of a small core
language with a large standard library and easily extensible interpreter stemmed from his
frustrations with ABC, which espoused the opposite approach.
Python strives for a simpler, less-cluttered syntax and grammar while giving developers a
choice in their coding methodology. In contrast to Perl's "there is more than one way to do it"
motto, Python embraces a "there should be one—and preferably only one—obvious way to
5
do it" design philosophy. Alex Martelli, a Fellow at the Python Software Foundation and
Python book author, writes that "To describe something as 'clever' is not considered a
compliment in the Python culture."
Python's developers strive to avoid premature optimization, and reject patches to non-critical
parts of the CPython reference implementation that would offer marginal increases in speed
at the cost of clarity. When speed is important, a Python programmer can move time-critical
functions to extension modules written in languages such as C, or use 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 keeping it fun to use. This is reflected in the
language's name—a tribute to the British comedy group Monty Python and in occasionally
playful approaches to tutorials and reference materials, such as examples that refer to spam
and eggs (from a famous Monty Python sketch) 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, Pthonistas, and Pythoneers.
Python is meant to be an easily readable language. Its formatting is visually uncluttered, and
it often uses English keywords where other languages use punctuation. Unlike many other
languages, it does not use curly brackets to delimit blocks, and semicolons after statements
are optional. It has fewer syntactic exceptions and special cases than C or Pascal.
6
Indentation
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 with else and elif (a
contraction of else-if).
7
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 by except clauses; it also ensures that clean-up code in a finally block will always be
run regardless of how the block exits.
The raise statement, used to raise a specified exception or re-raise a caught exception.
The class statement, which executes a block of code and attaches its local namespace to
a class, for use in object-oriented programming.
The with statement, from Python 2.5 released on September 2006, [66] 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 and replaces a common try/finally idiom.[67]
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 three ways of using import: import <module name>
[as <alias>] or from <module name> import * or from <module name> import <definition
1> [as <alias 1>], <definition 2> [as <alias 2>]
Python does not support tail call optimization or first-class continuations, and, according to
Guido van Rossum, it never will. However, better support for coroutine-like functionality is
8
provided in 2.5, by extending Python's generators. 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
Some Python expressions are similar to languages such as C and Java, while some are not:
Addition, subtraction, and multiplication are the same, but the behavior of division differs.
There are two types of divisions in Python. They are floor division (or integer division) // and
floating point/division. Python also added the ** operator for exponentiation.
From Python 3.5, the new @ infix operator was introduced. It is intended to be used by
libraries such as NumPy for matrix multiplication.
From Python 3.8, the syntax :=, called as 'walrus operator' was introduced. It assigns values
to variables as part of a larger expression.
In Python, == compares by value, versus Java, which compares numerics by value[77] and
objects by reference.[78] (Value comparisons in Java on objects can be performed with
the equals() method.) Python's is operator may be used to compare object identities
(comparison by reference). In Python, comparisons may be chained, for example a <= 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.[53]
Anonymous functions are implemented using lambda expressions; however, these are limited
in that the body can only be one expression.
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
9
be immutable 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. The + operator
can be used to concatenate two tuples, which does not directly modify their contents, but
rather produces a new tuple containing the elements of both provided tuples. Thus, given the
variable t initially equal to (1, 2, 3), executing t = t + (4, 5) first evaluates t + (4, 5), which
yields (1, 2, 3, 4, 5), which is then assigned back to t, thereby effectively "modifying the
contents" of t, while conforming to the immutable nature of tuple objects. Parentheses are
optional for tuples in unambiguous contexts.
Python features sequence unpacking where multiple expressions, each evaluating to anything
that can be assigned to (a variable, a writable property, etc.), are associated in the identical
manner to that forming tuple literals and, as a whole, are put on the left hand side of the equal
sign in an assignment statement. The statement expects an iterable object on the right hand
side of the equal sign that produces the same number of values as the provided writable
expressions when iterated through, and will iterate through it, assigning each of the produced
values to the corresponding expression on the left.
Python has a "string format" operator %. This functions analogous to printf 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 the format() method of the str class, e.g. "spam={0}
eggs={1}".format("blah", 2). Python 3.6 added "f-strings": blah = "blah"; eggs = 2;
f'spam={blah} eggs={eggs}'.[82]
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".
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.
10
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#.
Python has array index and array slicing expressions on lists, denoted
as a[key], a[start:stop] or a[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 example a[:] returns a copy of the entire list.
Each element of a slice is a shallow copy.
The eval() vs. exec() built-in functions (in Python 2, exec is a statement); the former is for
expressions, the latter is for statements.
Methods
11
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
Typing
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 metaprogramming and reflection.
Before version 3.0, Python had two kinds of classes: old-style and new-style.[84] 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.
12
The long term plan is to support gradual typing 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.
True
bool immutable Boolean value
False
bytearray(b'Some
ASCII')
bytearray(b"Some
bytearray mutable Sequence of bytes
ASCII")
bytearray([119, 105,
107, 105])
b'Some ASCII'
b"Some ASCII"
bytes immutable Sequence of bytes
bytes([119, 105, 107,
105])
13
as an index in NumPy arrays Ellipsis
list mutable List, can contain mixed types [4.0, 'string', True]
'Wikipedia'
"Wikipedia"
A character string: sequence of
str immutable """Spanning
Unicode codepoints
multiple
lines"""
A Sequence of numbers
commonly used for looping
range immutable range(1, 10)
specific number of times
in for loops[88]
Python has the usual symbols for arithmetic operators ( +, -, *, /), and the remainder
operator % (where the remainder can be negative, e.g. 4%-3 == -2). It also has ** for
exponentiation as in the C language, e.g. 5**3 == 125 and 9**0.5 == 3.0, and a new matrix
multiply @ operator is included in version 3.5. I.e. all these operators work as in traditional
math; with same precedence rules, the operators infix (or - can additionally be unary).
Additionally, it has a unary operator ( ~), which essentially inverts all the bits of its one
argument. For integers, this means ~x=-x-1.[90] 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 so that division between
integers produces accurate floating point results:
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. So 7//3 == 2, -7//3 == -3, 7.5//3 ==
2.0 and -7.5//3 == -3.0. Adding from __future__ import division causes a module to use
Python 3.0 rules for division (see next).
Python 3.0 changes / to always be floating-point division, e.g. 5/2 == 2.5. In Python terms,
the pre-3.0 / is classic division, the version-3.0 / is true 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.
15
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.
[94]
Python 3 uses round to even: round(1.5) is 2, round(2.5) is 2.
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.[96] 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.
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. [98] (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 module decimal (since
version 2.4) provides decimal floating point numbers to arbitrary precision and several
rounding modes. The Fraction type in module fractions (since version 2.6) provides arbitrary
precision for rational numbers.
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.
print('Hello, world!')
if n < 0:
16
else:
fact = 1
i=2
while i <= n:
fact = fact * i
i += 1
print(fact)
Libraries
Python's large standard library, commonly cited as one of its greatest strengths, provides tools
suited to many tasks. For Internet-facing applications, many standard formats and protocols
such as MIME and HTTP are supported. It includes modules for creating graphical user
interfaces, connecting to relational databases, generating pseudorandom numbers, arithmetic
with arbitrary-precision decimals, manipulating regular expressions, and unit testing.
Some parts of the standard library are covered by specifications (for example, the Web Server
Gateway Interface (WSGI) implementation wsgiref follows PEP 333), but most modules are
not. They are specified by their code, internal documentation, and test suites (if supplied).
However, because most of the standard library is cross-platform Python code, only a few
modules need altering or rewriting for variant implementations.
As of March 2018, the Python Package Index (PyPI), the official repository for third-party
Python software, contains over 130,000[106] packages with a wide range of functionality,
including:
Web frameworks
Multimedia
Databases
Networking
17
Test frameworks
Automation
Web scraping
Documentation
System administration
Scientific computing
Text processing
Image processing
Development environments
Other shells, including IDLE and IPython, add further abilities such as auto-completion,
session state retention and syntax highlighting.
As well as standard desktop integrated development environments, there are Web browser-
based IDEs; SageMath (intended for developing science and math-related Python
programs); PythonAnywhere, a browser-based IDE and hosting environment; and Canopy
IDE, a commercial Python IDE emphasizing scientific computing.
Reference implementation
18
many platforms, including Windows and most modern Unix-like systems. Platform
portability was one of its earliest priorities.
Other implementations
PyPy is a fast, compliant interpreter of Python 2.7 and 3.5. Its just-in-time compiler brings a
significant speed improvement over CPython.
Stackless Python is a significant fork of CPython that implements microthreads; it does not
use the C memory stack, thus allowing massively concurrent programs. PyPy also has a
stackless version.
MicroPython and CircuitPython are Python 3 variants optimized for microcontrollers. This
includes Lego Mindstorms EV3.
Unsupported implementations
Other just-in-time Python compilers have been developed, but are now unsupported:
Google began a project named Unladen Swallow in 2009, with the aim of speeding up the
Python interpreter five-fold by using the LLVM, and of improving its multithreading ability
to scale to thousands of cores.
Psyco is a just-in-time specialising compiler that integrates with CPython and transforms
bytecode to machine code at runtime. The emitted code is specialized for certain data
types and is faster than standard Python code.
In 2005, Nokia released a Python interpreter for the Series 60 mobile phones named PyS60. It
includes many of the modules from the CPython implementations and some additional
modules to integrate with the Symbian operating system. The project has been kept up-to-
date to run on all variants of the S60 platform, and several third-party modules are available.
The Nokia N900 also supports Python with GTK widget libraries, enabling programs to be
written and run on the target device.
There are several compilers to high-level object languages, with either unrestricted Python, a
restricted subset of Python, or a language similar to Python as the source language:
19
Jython compiles into Java byte code, which can then be executed by every Java virtual
machine implementation. This also enables the use of Java class library functions from the
Python program.
Somewhat dated Pyrex (latest release in 2010) and Shed Skin (latest release in 2013) compile
to C and C++ respectively.
Performance
Development
Python's development is conducted largely through the Python Enhancement Proposal (PEP)
process, the primary mechanism for proposing major new features, collecting community
input on issues and documenting Python design decisions. Python coding style is covered in
PEP 8. Outstanding PEPs are reviewed and commented on by the Python community and the
steering council.
20
Enhancement of the language corresponds with development of the CPython reference
implementation. The mailing list python-dev is the primary forum for the language's
development. Specific issues are discussed in the Roundup bug tracker maintained at
python.org. Development originally took place on a self-hosted source-code repository
running Mercurial, until Python moved to GitHub in January 2017.
CPython's public releases come in three types, distinguished by which part of the version
number is incremented:
Major or "feature" releases, about every 18 months, are largely compatible but introduce new
features. The second part of the version number is incremented. Each major version is
supported by bugfixes for several years after its release.
Bugfix releases, which introduce no new features, occur about every 3 months and are made
when a sufficient number of bugs have been fixed upstream since the last release. Security
vulnerabilities are also patched in these releases. The third and final part of the version
number is incremented.
Many alpha, beta, and release-candidates are also released as previews and for testing before
final releases. Although there is a rough schedule for each release, they are often delayed if
the code is not ready. Python's development team monitors the state of the code by running
the large unit test suite during development, and using the BuildBot continuous
integration system.
The community of Python developers has also contributed over 86,000[129] software modules
(as of 20 August 2016) to the Python Package Index (PyPI), the official repository of third-
party Python libraries.
The major academic conference on Python is PyCon. There are also special Python
mentoring programmes, such as Pyladies.
21
Naming
Python's name is derived from the British comedy group Monty Python, whom Python
creator Guido van Rossum enjoyed while developing the language. Monty Python references
appear frequently in Python code and culture;[130] for example, the metasyntactic
variables often used in Python literature are spam and eggs instead of the
traditional foo and bar. The official Python documentation also contains various references to
Monty Python routines.
The prefix Py- is used to show that something is related to Python. Examples of the use of
this prefix in names of Python applications or libraries include Pygame, a binding of SDL to
Python (commonly used to create games); PyQt and PyGTK, which bind Qt and GTK to
Python respectively; and PyPy, a Python implementation originally written in Python.
Sphinx
Epydoc
HeaderDoc
pydoc
Uses
Since 2003, Python has consistently ranked in the top ten most popular programming
languages in the TIOBE Programming Community Index where, as of December 2018, it is
the third most popular language (behind Java, and C). It was selected Programming Language
of the Year in 2007, 2010, and 2018.
An empirical study found that scripting languages, such as Python, are more productive than
conventional languages, such as C and Java, for programming problems involving string
manipulation and search in a dictionary, and determined that memory consumption was often
"better than Java and not much worse than C or C++".
22
]
and some smaller entities like ILM and ITA. The social news networking site Reddit is
written entirely in Python.
Python can serve as a scripting language for web applications, e.g., via mod_wsgi for
the Apache web server. With Web Server Gateway Interface, a standard API has evolved to
facilitate these applications. Web
frameworks like Django, Pylons, Pyramid, TurboGears, web2py, Tornado, Flask, Bottle and
Zope support developers in the design and maintenance of complex
applications. Pyjs and IronPython can be used to develop the client-side of Ajax-based
applications. SQLAlchemy can be used as data mapper to a relational database. Twisted is a
framework to program communications between computers, and is used (for example)
by Dropbox.
Libraries such as NumPy, SciPy and Matplotlib allow the effective use of Python in scientific
computing,[148][149] with specialized libraries such as Biopython and Astropy providing
domain-specific functionality. SageMath is a mathematical software with a notebook
interface programmable in Python: its library covers many aspects of mathematics,
including algebra, combinatorics, numerical mathematics, number theory, and calculus.
Python has been successfully embedded in many software products as a scripting language,
including in finite element method software such as Abaqus, 3D parametric modeler
like FreeCAD, 3D animation packages such as 3ds Max, Blender, Cinema
4D, Lightwave, Houdini, Maya, modo, MotionBuilder, Softimage, the visual effects
compositor Nuke, 2D imaging programs like GIMP, Inkscape, Scribus and Paint Shop Pro,
[151]
and musical notation programs like scorewriter and capella. GNU Debugger uses Python
as a pretty printer to show complex structures such as C++ containers. Esri promotes Python
as the best choice for writing scripts in ArcGIS. It has also been used in several video games,
[153][154]
and has been adopted as first of the three available programming languages in Google
App Engine, the other two being Java and Go.
Python is commonly used in artificial intelligence projects with the help of libraries
like TensorFlow, Keras and Scikit-learn. As a scripting language with modular architecture,
simple syntax and rich text processing tools, Python is often used for natural language
processing.
23
Many operating systems include Python as a standard component. It ships with most Linux
distributions, AmigaOS 4, FreeBSD (as a package), NetBSD, OpenBSD (as a package)
and macOS and can be used from the command line (terminal). Many Linux distributions use
installers written in Python: Ubuntu uses the Ubiquity installer, while Red Hat
Linux and Fedora use the Anaconda installer. Gentoo Linux uses Python in its package
management system, Portage.
Most of the Sugar software for the One Laptop per Child XO, now developed at Sugar Labs,
is written in Python. The Raspberry Pi single-board computer project has adopted Python as
its main user-programming language.
LibreOffice includes Python, and intends to replace Java with Python. Its Python Scripting
Provider is a core feature since Version 4.0 from 7 February 2013.
Python's design and philosophy have influenced many other programming languages:
Cobra uses indentation and a similar syntax, and its "Acknowledgements" document lists
Python first among languages that influenced it. However, Cobra directly supports design-by-
contract, unit tests, and optional static typing.
Go is designed for the "speed of working in a dynamic language like Python" and shares the
same syntax for slicing arrays.
Groovy was motivated by the desire to bring the Python design philosophy to Java.
Julia was designed "with true macros [.. and to be] as usable for general programming as
Python [and] should be as fast as C".Calling to or from Julia is possible; to with PyCall.jl and
a Python package pyjulia allows calling, in the other direction, from Python.
24
Kotlin is a functional programming language with an interactive shell similar to Python.
However, Kotlin is strongly typed with access to standard Java libraries.
Ruby's creator, Yukihiro Matsumoto, has said: "I wanted a scripting language that was more
powerful than Perl, and more object-oriented than Python. That's why I decided to design my
own language."
Python's development practices have also been emulated by other languages. For example,
the practice of requiring a document describing the rationale for, and issues surrounding, a
change to the language (in Python, a PEP) is also used in Tcl and Erlang.
Python received TIOBE's Programming Language of the Year awards in 2007, 2010 and
2018. The award is given to the language with the greatest growth in popularity over the year,
as measured by the TIOBE index.
25
Python program to add two numbers
Given two numbers num1 and num2. The task is to write a Python program to
find the addition of these two numbers.
Examples:
Input: num1 = 5, num2 = 3
Output: 8
Output: 19
In the below program to add two numbers, the user is first asked to enter two
numbers and the input is scanned using the input() function and stored in the
variables number1 and number2. Then, the variables number1 and number2 are
added using the arithmetic operator + and the result is stored in the variable
sum.
Example 1:
filter_none
edit
play_arrow
brightness_4
# Python3 program to add two numbers
26
num1 = 15
num2 = 12
# printing values
Sum of 15 and 12 is 27
edit
play_arrow
brightness_4
# Python3 program to add two numbers
27
print("The sum of {0} and {1} is {2}" .format(number1, number2, sum))
Output:
Recursive :
filter_none
edit
play_arrow
brightness_4
# Python 3 program to find
def factorial(n):
# Driver Code
num = 5;
print("Factorial of",num,"is",
28
factorial(num))
edit
play_arrow
brightness_4
# Python 3 program to find
def factorial(n):
# Driver Code
num = 5;
print("Factorial of",num,"is",
factorial(num))
edit
play_arrow
brightness_4
29
# Python 3 program to find
def factorial(n):
# Driver Code
num = 5
factorial(num))
EXAMPLE1:
30
Input : P = 10000
R=5
T=5
Output :2500
units of time.
EXAMPLE2:
Input : P = 3000
R=7
T=1
Output :210
Python3
filter_none
edit
play_arrow
brightness_4
# Python3 program to find simple interest
31
# for given principal amount, time and
# rate of interest.
# different inputs
P=1
R=1
T=1
SI = (P * R * T) / 100
32
Python Program for compound interest
Time: 2
Rate: 5.4
Python3
filter_none edit play_arrow brightness_4
33
# Calculates compound interest
# Driver Code
compound_interest(10000, 10.25, 5)
34
Python Program for compound interest
Time: 2
Rate: 5.4
Python3
filter_none
edit
play_arrow
brightness_4
# Python3 program to find compound
35
def compound_interest(principle, rate, time):
# Driver Code
compound_interest(10000, 10.25, 5)
36
Python Program to check Armstrong Number
Output : Yes
Input : 120
Output : No
Input : 1253
Output : No
37
Input : 1634
Output : Yes
Python
filter_none
edit
play_arrow
brightness_4
# Python program to determine whether the number is
if y==0:
return 1
if y%2==0:
def order(x):
38
# variable to store of the number
n=0
while (x!=0):
n = n+1
x = x/10
return n
n = order(x)
temp = x
sum1 = 0
while (temp!=0):
r = temp%10
temp = temp/10
# If condition satisfies
return (sum1 == x)
39
# Driver Program
x = 153
print(isArmstrong(x))
x = 1253
print(isArmstrong(x))
40
Python Program for Program to find area of a circle
Area = pi * r2
where r is radius of circle
Python3
filter_none
edit
play_arrow
brightness_4
# Python program to find Area of a circle
def findArea(r):
PI = 3.142
return PI * (r*r);
# Driver method
41
Python program to print all Prime numbers in an Interval
Given two positive integer start and end. The task is to write a Python
program toprint all Prime numbers in an Interval.
filter_none
edit
play_arrow
brightness_4
42
# Python program to print all
start = 11
end = 25
if val > 1:
if (val % n) == 0:
break
else:
print(val)
Output:
11
13
17
43
19
23
Given a positive integer N. The task is to write a Python program to check if the
number is prime or not.
Definition: A prime number is a natural number greater than 1 that has no
positive divisors other than 1 and itself. The first few prime numbers are {2, 3,
5, 7, 11, ….}.
Examples :
Input: n = 11
Output: true
Input: n = 15
Output: false
44
Input: n = 1
Output: false
The idea to solve this problem is to iterate through all the numbers starting from
2 to (N/2) using a for loop and for every number check if it divides N. If we find
any number that divides, we return false. If we did not find any number between
2 and N/2 which divides N then it means that N is prime and we will return
True.
filter_none
edit
play_arrow
brightness_4
# Python program to check if
num = 11
if num > 1:
# Iterate from 2 to n / 2
if (num % i) == 0:
45
print(num, "is not a prime number")
break
else:
else:
Optimized Method
We can do following optimizations:
Instead of checking till n, we can check till √n because a larger factor of n must
be a multiple of smaller factor that has been already checked.
The algorithm can be improved further by observing that all primes are of the
form 6k ± 1, with the exception of 2 and 3. This is because all integers can be
expressed as (6k + i) for some integer k and for i = ?1, 0, 1, 2, 3, or 4; 2 divides
(6k + 0), (6k + 2), (6k + 4); and 3 divides (6k + 3). So a more efficient method is
to test if n is divisible by 2 or 3, then to check through all the numbers of form
6k ± 1. (Source: wikipedia)
filter_none
edit
play_arrow
brightness_4
46
# if a number is prime
def isPrime(n) :
# Corner cases
if (n <= 1) :
return False
if (n <= 3) :
return True
if (n % 2 == 0 or n % 3 == 0) :
return False
i=5
while(i * i <= n) :
if (n % i == 0 or n % (i + 2) == 0) :
return False
i=i+6
return True
# Driver Program
47
if (isPrime(11)) :
print(" true")
else :
print(" false")
if(isPrime(15)) :
print(" true")
else :
print(" false")
# by Nikita Tiwari.
REFERENCES
"The Android Source Code". source.android.com. Retrieved February 2, 2017.
48
Syed H (September 24, 2012). "Editorial: Why You Should Go Nexus". Droid
Lessons. Retrieved April 17, 2013.
49