2009-10-11 18:25:26 -03:00
|
|
|
:tocdepth: 2
|
|
|
|
|
|
|
|
==================
|
|
|
|
General Python FAQ
|
|
|
|
==================
|
|
|
|
|
2013-03-28 09:28:44 -03:00
|
|
|
.. only:: html
|
|
|
|
|
|
|
|
.. contents::
|
|
|
|
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
General Information
|
|
|
|
===================
|
|
|
|
|
|
|
|
What is Python?
|
|
|
|
---------------
|
|
|
|
|
|
|
|
Python is an interpreted, interactive, object-oriented programming language. It
|
|
|
|
incorporates modules, exceptions, dynamic typing, very high level dynamic data
|
2020-06-08 15:53:25 -03:00
|
|
|
types, and classes. It supports multiple programming paradigms beyond
|
|
|
|
object-oriented programming, such as procedural and functional programming.
|
|
|
|
Python combines remarkable power with very clear syntax. It has interfaces to
|
|
|
|
many system calls and libraries, as well as to various window systems, and is
|
|
|
|
extensible in C or C++. It is also usable as an extension language for
|
|
|
|
applications that need a programmable interface. Finally, Python is portable:
|
|
|
|
it runs on many Unix variants including Linux and macOS, and on Windows.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
To find out more, start with :ref:`tutorial-index`. The `Beginner's Guide to
|
2014-10-29 04:36:35 -03:00
|
|
|
Python <https://wiki.python.org/moin/BeginnersGuide>`_ links to other
|
2009-10-11 18:25:26 -03:00
|
|
|
introductory tutorials and resources for learning Python.
|
|
|
|
|
|
|
|
|
|
|
|
What is the Python Software Foundation?
|
|
|
|
---------------------------------------
|
|
|
|
|
|
|
|
The Python Software Foundation is an independent non-profit organization that
|
|
|
|
holds the copyright on Python versions 2.1 and newer. The PSF's mission is to
|
|
|
|
advance open source technology related to the Python programming language and to
|
|
|
|
publicize the use of Python. The PSF's home page is at
|
2014-10-29 04:36:35 -03:00
|
|
|
https://www.python.org/psf/.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
Donations to the PSF are tax-exempt in the US. If you use Python and find it
|
|
|
|
helpful, please contribute via `the PSF donation page
|
2014-10-29 04:36:35 -03:00
|
|
|
<https://www.python.org/psf/donations/>`_.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
Are there copyright restrictions on the use of Python?
|
|
|
|
------------------------------------------------------
|
|
|
|
|
|
|
|
You can do anything you want with the source, as long as you leave the
|
|
|
|
copyrights in and display those copyrights in any documentation about Python
|
|
|
|
that you produce. If you honor the copyright rules, it's OK to use Python for
|
|
|
|
commercial use, to sell copies of Python in source or binary form (modified or
|
|
|
|
unmodified), or to sell products that incorporate Python in some form. We would
|
|
|
|
still like to know about all commercial use of Python, of course.
|
|
|
|
|
2015-05-27 19:37:00 -03:00
|
|
|
See `the PSF license page <https://www.python.org/psf/license/>`_ to find further
|
2009-10-11 18:25:26 -03:00
|
|
|
explanations and a link to the full text of the license.
|
|
|
|
|
|
|
|
The Python logo is trademarked, and in certain cases permission is required to
|
|
|
|
use it. Consult `the Trademark Usage Policy
|
2014-10-29 04:36:35 -03:00
|
|
|
<https://www.python.org/psf/trademarks/>`__ for more information.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
Why was Python created in the first place?
|
|
|
|
------------------------------------------
|
|
|
|
|
|
|
|
Here's a *very* brief summary of what started it all, written by Guido van
|
|
|
|
Rossum:
|
|
|
|
|
|
|
|
I had extensive experience with implementing an interpreted language in the
|
|
|
|
ABC group at CWI, and from working with this group I had learned a lot about
|
|
|
|
language design. This is the origin of many Python features, including the
|
|
|
|
use of indentation for statement grouping and the inclusion of
|
|
|
|
very-high-level data types (although the details are all different in
|
|
|
|
Python).
|
|
|
|
|
|
|
|
I had a number of gripes about the ABC language, but also liked many of its
|
|
|
|
features. It was impossible to extend the ABC language (or its
|
|
|
|
implementation) to remedy my complaints -- in fact its lack of extensibility
|
|
|
|
was one of its biggest problems. I had some experience with using Modula-2+
|
|
|
|
and talked with the designers of Modula-3 and read the Modula-3 report.
|
|
|
|
Modula-3 is the origin of the syntax and semantics used for exceptions, and
|
|
|
|
some other Python features.
|
|
|
|
|
|
|
|
I was working in the Amoeba distributed operating system group at CWI. We
|
|
|
|
needed a better way to do system administration than by writing either C
|
|
|
|
programs or Bourne shell scripts, since Amoeba had its own system call
|
|
|
|
interface which wasn't easily accessible from the Bourne shell. My
|
|
|
|
experience with error handling in Amoeba made me acutely aware of the
|
|
|
|
importance of exceptions as a programming language feature.
|
|
|
|
|
|
|
|
It occurred to me that a scripting language with a syntax like ABC but with
|
|
|
|
access to the Amoeba system calls would fill the need. I realized that it
|
|
|
|
would be foolish to write an Amoeba-specific language, so I decided that I
|
|
|
|
needed a language that was generally extensible.
|
|
|
|
|
|
|
|
During the 1989 Christmas holidays, I had a lot of time on my hand, so I
|
|
|
|
decided to give it a try. During the next year, while still mostly working
|
|
|
|
on it in my own time, Python was used in the Amoeba project with increasing
|
|
|
|
success, and the feedback from colleagues made me add many early
|
|
|
|
improvements.
|
|
|
|
|
|
|
|
In February 1991, after just over a year of development, I decided to post to
|
|
|
|
USENET. The rest is in the ``Misc/HISTORY`` file.
|
|
|
|
|
|
|
|
|
|
|
|
What is Python good for?
|
|
|
|
------------------------
|
|
|
|
|
|
|
|
Python is a high-level general-purpose programming language that can be applied
|
|
|
|
to many different classes of problems.
|
|
|
|
|
|
|
|
The language comes with a large standard library that covers areas such as
|
|
|
|
string processing (regular expressions, Unicode, calculating differences between
|
|
|
|
files), Internet protocols (HTTP, FTP, SMTP, XML-RPC, POP, IMAP, CGI
|
|
|
|
programming), software engineering (unit testing, logging, profiling, parsing
|
|
|
|
Python code), and operating system interfaces (system calls, filesystems, TCP/IP
|
|
|
|
sockets). Look at the table of contents for :ref:`library-index` to get an idea
|
|
|
|
of what's available. A wide variety of third-party extensions are also
|
2018-05-15 15:58:35 -03:00
|
|
|
available. Consult `the Python Package Index <https://pypi.org>`_ to
|
2009-10-11 18:25:26 -03:00
|
|
|
find packages of interest to you.
|
|
|
|
|
|
|
|
|
|
|
|
How does the Python version numbering scheme work?
|
|
|
|
--------------------------------------------------
|
|
|
|
|
|
|
|
Python versions are numbered A.B.C or A.B. A is the major version number -- it
|
|
|
|
is only incremented for really major changes in the language. B is the minor
|
|
|
|
version number, incremented for less earth-shattering changes. C is the
|
|
|
|
micro-level -- it is incremented for each bugfix release. See :pep:`6` for more
|
|
|
|
information about bugfix releases.
|
|
|
|
|
|
|
|
Not all releases are bugfix releases. In the run-up to a new major release, a
|
|
|
|
series of development releases are made, denoted as alpha, beta, or release
|
|
|
|
candidate. Alphas are early releases in which interfaces aren't yet finalized;
|
|
|
|
it's not unexpected to see an interface change between two alpha releases.
|
|
|
|
Betas are more stable, preserving existing interfaces but possibly adding new
|
|
|
|
modules, and release candidates are frozen, making no changes except as needed
|
|
|
|
to fix critical bugs.
|
|
|
|
|
|
|
|
Alpha, beta and release candidate versions have an additional suffix. The
|
|
|
|
suffix for an alpha version is "aN" for some small number N, the suffix for a
|
|
|
|
beta version is "bN" for some small number N, and the suffix for a release
|
|
|
|
candidate version is "cN" for some small number N. In other words, all versions
|
|
|
|
labeled 2.0aN precede the versions labeled 2.0bN, which precede versions labeled
|
|
|
|
2.0cN, and *those* precede 2.0.
|
|
|
|
|
|
|
|
You may also find version numbers with a "+" suffix, e.g. "2.2+". These are
|
2016-05-27 03:18:51 -03:00
|
|
|
unreleased versions, built directly from the CPython development repository. In
|
|
|
|
practice, after a final minor release is made, the version is incremented to the
|
|
|
|
next minor version, which becomes the "a0" version, e.g. "2.4a0".
|
2009-10-11 18:25:26 -03:00
|
|
|
|
2015-10-12 03:03:22 -03:00
|
|
|
See also the documentation for :data:`sys.version`, :data:`sys.hexversion`, and
|
|
|
|
:data:`sys.version_info`.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
How do I obtain a copy of the Python source?
|
|
|
|
--------------------------------------------
|
|
|
|
|
|
|
|
The latest Python source distribution is always available from python.org, at
|
2016-02-26 14:37:12 -04:00
|
|
|
https://www.python.org/downloads/. The latest development sources can be obtained
|
2017-02-16 11:18:42 -04:00
|
|
|
at https://github.com/python/cpython/.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
The source distribution is a gzipped tar file containing the complete C source,
|
|
|
|
Sphinx-formatted documentation, Python library modules, example programs, and
|
|
|
|
several useful pieces of freely distributable software. The source will compile
|
|
|
|
and run out of the box on most UNIX platforms.
|
|
|
|
|
2014-09-01 04:06:18 -03:00
|
|
|
Consult the `Getting Started section of the Python Developer's Guide
|
2017-08-30 13:37:43 -03:00
|
|
|
<https://devguide.python.org/setup/>`__ for more
|
Merged revisions 75365,75394,75402-75403,75418,75459,75484,75592-75596,75600,75602-75607,75610-75613,75616-75617,75623,75627,75640,75647,75696,75795 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r75365 | georg.brandl | 2009-10-11 22:16:16 +0200 (So, 11 Okt 2009) | 1 line
Fix broken links found by "make linkcheck". scipy.org seems to be done right now, so I could not verify links going there.
........
r75394 | georg.brandl | 2009-10-13 20:10:59 +0200 (Di, 13 Okt 2009) | 1 line
Fix markup.
........
r75402 | georg.brandl | 2009-10-14 17:51:48 +0200 (Mi, 14 Okt 2009) | 1 line
#7125: fix typo.
........
r75403 | georg.brandl | 2009-10-14 17:57:46 +0200 (Mi, 14 Okt 2009) | 1 line
#7126: os.environ changes *do* take effect in subprocesses started with os.system().
........
r75418 | georg.brandl | 2009-10-14 20:48:32 +0200 (Mi, 14 Okt 2009) | 1 line
#7116: str.join() takes an iterable.
........
r75459 | georg.brandl | 2009-10-17 10:57:43 +0200 (Sa, 17 Okt 2009) | 1 line
Fix refleaks in _ctypes PyCSimpleType_New, which fixes the refleak seen in test___all__.
........
r75484 | georg.brandl | 2009-10-18 09:58:12 +0200 (So, 18 Okt 2009) | 1 line
Fix missing word.
........
r75592 | georg.brandl | 2009-10-22 09:05:48 +0200 (Do, 22 Okt 2009) | 1 line
Fix punctuation.
........
r75593 | georg.brandl | 2009-10-22 09:06:49 +0200 (Do, 22 Okt 2009) | 1 line
Revert unintended change.
........
r75594 | georg.brandl | 2009-10-22 09:56:02 +0200 (Do, 22 Okt 2009) | 1 line
Fix markup.
........
r75595 | georg.brandl | 2009-10-22 09:56:56 +0200 (Do, 22 Okt 2009) | 1 line
Fix duplicate target.
........
r75596 | georg.brandl | 2009-10-22 10:05:04 +0200 (Do, 22 Okt 2009) | 1 line
Add a new directive marking up implementation details and start using it.
........
r75600 | georg.brandl | 2009-10-22 13:01:46 +0200 (Do, 22 Okt 2009) | 1 line
Make it more robust.
........
r75602 | georg.brandl | 2009-10-22 13:28:06 +0200 (Do, 22 Okt 2009) | 1 line
Document new directive.
........
r75603 | georg.brandl | 2009-10-22 13:28:23 +0200 (Do, 22 Okt 2009) | 1 line
Allow short form with text as argument.
........
r75604 | georg.brandl | 2009-10-22 13:36:50 +0200 (Do, 22 Okt 2009) | 1 line
Fix stylesheet for multi-paragraph impl-details.
........
r75605 | georg.brandl | 2009-10-22 13:48:10 +0200 (Do, 22 Okt 2009) | 1 line
Use "impl-detail" directive where applicable.
........
r75606 | georg.brandl | 2009-10-22 17:00:06 +0200 (Do, 22 Okt 2009) | 1 line
#6324: membership test tries iteration via __iter__.
........
r75607 | georg.brandl | 2009-10-22 17:04:09 +0200 (Do, 22 Okt 2009) | 1 line
#7088: document new functions in signal as Unix-only.
........
r75610 | georg.brandl | 2009-10-22 17:27:24 +0200 (Do, 22 Okt 2009) | 1 line
Reorder __slots__ fine print and add a clarification.
........
r75611 | georg.brandl | 2009-10-22 17:42:32 +0200 (Do, 22 Okt 2009) | 1 line
#7035: improve docs of the various <method>_errors() functions, and give them docstrings.
........
r75612 | georg.brandl | 2009-10-22 17:52:15 +0200 (Do, 22 Okt 2009) | 1 line
#7156: document curses as Unix-only.
........
r75613 | georg.brandl | 2009-10-22 17:54:35 +0200 (Do, 22 Okt 2009) | 1 line
#6977: getopt does not support optional option arguments.
........
r75616 | georg.brandl | 2009-10-22 18:17:05 +0200 (Do, 22 Okt 2009) | 1 line
Add proper references.
........
r75617 | georg.brandl | 2009-10-22 18:20:55 +0200 (Do, 22 Okt 2009) | 1 line
Make printout margin important.
........
r75623 | georg.brandl | 2009-10-23 10:14:44 +0200 (Fr, 23 Okt 2009) | 1 line
#7188: fix optionxform() docs.
........
r75627 | fred.drake | 2009-10-23 15:04:51 +0200 (Fr, 23 Okt 2009) | 2 lines
add further note about what's passed to optionxform
........
r75640 | neil.schemenauer | 2009-10-23 21:58:17 +0200 (Fr, 23 Okt 2009) | 2 lines
Improve some docstrings in the 'warnings' module.
........
r75647 | georg.brandl | 2009-10-24 12:04:19 +0200 (Sa, 24 Okt 2009) | 1 line
Fix markup.
........
r75696 | georg.brandl | 2009-10-25 21:25:43 +0100 (So, 25 Okt 2009) | 1 line
Fix a demo.
........
r75795 | georg.brandl | 2009-10-27 16:10:22 +0100 (Di, 27 Okt 2009) | 1 line
Fix a strange mis-edit.
........
2009-10-27 12:28:25 -03:00
|
|
|
information on getting the source code and compiling it.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
How do I get documentation on Python?
|
|
|
|
-------------------------------------
|
|
|
|
|
|
|
|
.. XXX mention py3k
|
|
|
|
|
|
|
|
The standard documentation for the current stable version of Python is available
|
2014-10-29 06:57:37 -03:00
|
|
|
at https://docs.python.org/3/. PDF, plain text, and downloadable HTML versions are
|
|
|
|
also available at https://docs.python.org/3/download.html.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
The documentation is written in reStructuredText and processed by `the Sphinx
|
2014-01-25 14:27:06 -04:00
|
|
|
documentation tool <http://sphinx-doc.org/>`__. The reStructuredText source for
|
|
|
|
the documentation is part of the Python source distribution.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
I've never programmed before. Is there a Python tutorial?
|
|
|
|
---------------------------------------------------------
|
|
|
|
|
|
|
|
There are numerous tutorials and books available. The standard documentation
|
|
|
|
includes :ref:`tutorial-index`.
|
|
|
|
|
2014-10-29 04:36:35 -03:00
|
|
|
Consult `the Beginner's Guide <https://wiki.python.org/moin/BeginnersGuide>`_ to
|
2009-10-11 18:25:26 -03:00
|
|
|
find information for beginning Python programmers, including lists of tutorials.
|
|
|
|
|
|
|
|
|
|
|
|
Is there a newsgroup or mailing list devoted to Python?
|
|
|
|
-------------------------------------------------------
|
|
|
|
|
|
|
|
There is a newsgroup, :newsgroup:`comp.lang.python`, and a mailing list,
|
2014-10-29 06:57:37 -03:00
|
|
|
`python-list <https://mail.python.org/mailman/listinfo/python-list>`_. The
|
2009-10-11 18:25:26 -03:00
|
|
|
newsgroup and mailing list are gatewayed into each other -- if you can read news
|
|
|
|
it's unnecessary to subscribe to the mailing list.
|
|
|
|
:newsgroup:`comp.lang.python` is high-traffic, receiving hundreds of postings
|
|
|
|
every day, and Usenet readers are often more able to cope with this volume.
|
|
|
|
|
|
|
|
Announcements of new software releases and events can be found in
|
|
|
|
comp.lang.python.announce, a low-traffic moderated list that receives about five
|
|
|
|
postings per day. It's available as `the python-announce mailing list
|
2014-10-29 06:57:37 -03:00
|
|
|
<https://mail.python.org/mailman/listinfo/python-announce-list>`_.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
More info about other mailing lists and newsgroups
|
2014-10-29 04:36:35 -03:00
|
|
|
can be found at https://www.python.org/community/lists/.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
How do I get a beta test version of Python?
|
|
|
|
-------------------------------------------
|
|
|
|
|
2016-02-26 14:37:12 -04:00
|
|
|
Alpha and beta releases are available from https://www.python.org/downloads/. All
|
2009-10-11 18:25:26 -03:00
|
|
|
releases are announced on the comp.lang.python and comp.lang.python.announce
|
2014-10-29 04:36:35 -03:00
|
|
|
newsgroups and on the Python home page at https://www.python.org/; an RSS feed of
|
2009-10-11 18:25:26 -03:00
|
|
|
news is available.
|
|
|
|
|
2017-02-16 11:18:42 -04:00
|
|
|
You can also access the development version of Python through Git. See
|
2017-08-30 13:37:43 -03:00
|
|
|
`The Python Developer's Guide <https://devguide.python.org/>`_ for details.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
How do I submit bug reports and patches for Python?
|
|
|
|
---------------------------------------------------
|
|
|
|
|
|
|
|
To report a bug or submit a patch, please use the Roundup installation at
|
2014-10-29 04:36:35 -03:00
|
|
|
https://bugs.python.org/.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
You must have a Roundup account to report bugs; this makes it possible for us to
|
|
|
|
contact you if we have follow-up questions. It will also enable Roundup to send
|
|
|
|
you updates as we act on your bug. If you had previously used SourceForge to
|
|
|
|
report bugs to Python, you can obtain your Roundup password through Roundup's
|
2014-10-29 04:36:35 -03:00
|
|
|
`password reset procedure <https://bugs.python.org/user?@template=forgotten>`_.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
For more information on how Python is developed, consult `the Python Developer's
|
2017-08-30 13:37:43 -03:00
|
|
|
Guide <https://devguide.python.org/>`_.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
Are there any published articles about Python that I can reference?
|
|
|
|
-------------------------------------------------------------------
|
|
|
|
|
|
|
|
It's probably best to cite your favorite book about Python.
|
|
|
|
|
|
|
|
The very first article about Python was written in 1991 and is now quite
|
|
|
|
outdated.
|
|
|
|
|
|
|
|
Guido van Rossum and Jelke de Boer, "Interactively Testing Remote Servers
|
|
|
|
Using the Python Programming Language", CWI Quarterly, Volume 4, Issue 4
|
2016-11-26 07:43:28 -04:00
|
|
|
(December 1991), Amsterdam, pp 283--303.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
Are there any books on Python?
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
Yes, there are many, and more are being published. See the python.org wiki at
|
2014-10-29 04:36:35 -03:00
|
|
|
https://wiki.python.org/moin/PythonBooks for a list.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
You can also search online bookstores for "Python" and filter out the Monty
|
|
|
|
Python references; or perhaps search for "Python" and "language".
|
|
|
|
|
|
|
|
|
|
|
|
Where in the world is www.python.org located?
|
|
|
|
---------------------------------------------
|
|
|
|
|
2019-02-27 18:23:34 -04:00
|
|
|
The Python project's infrastructure is located all over the world and is managed
|
|
|
|
by the Python Infrastructure Team. Details `here <http://infra.psf.io>`__.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
Why is it called Python?
|
|
|
|
------------------------
|
|
|
|
|
|
|
|
When he began implementing Python, Guido van Rossum was also reading the
|
|
|
|
published scripts from `"Monty Python's Flying Circus"
|
2016-02-26 14:37:12 -04:00
|
|
|
<https://en.wikipedia.org/wiki/Monty_Python>`__, a BBC comedy series from the 1970s. Van Rossum
|
2009-10-11 18:25:26 -03:00
|
|
|
thought he needed a name that was short, unique, and slightly mysterious, so he
|
|
|
|
decided to call the language Python.
|
|
|
|
|
|
|
|
|
|
|
|
Do I have to like "Monty Python's Flying Circus"?
|
|
|
|
-------------------------------------------------
|
|
|
|
|
|
|
|
No, but it helps. :)
|
|
|
|
|
|
|
|
|
|
|
|
Python in the real world
|
|
|
|
========================
|
|
|
|
|
|
|
|
How stable is Python?
|
|
|
|
---------------------
|
|
|
|
|
|
|
|
Very stable. New, stable releases have been coming out roughly every 6 to 18
|
2020-06-30 06:51:21 -03:00
|
|
|
months since 1991, and this seems likely to continue. As of version 3.9,
|
|
|
|
Python will have a major new release every 12 months (:pep:`602`).
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
The developers issue "bugfix" releases of older versions, so the stability of
|
|
|
|
existing releases gradually improves. Bugfix releases, indicated by a third
|
2018-10-12 06:16:43 -03:00
|
|
|
component of the version number (e.g. 3.5.3, 3.6.2), are managed for stability;
|
2009-10-11 18:25:26 -03:00
|
|
|
only fixes for known problems are included in a bugfix release, and it's
|
|
|
|
guaranteed that interfaces will remain the same throughout a series of bugfix
|
|
|
|
releases.
|
|
|
|
|
2009-12-14 13:27:08 -04:00
|
|
|
The latest stable releases can always be found on the `Python download page
|
2019-03-26 18:10:40 -03:00
|
|
|
<https://www.python.org/downloads/>`_. There are two production-ready versions
|
|
|
|
of Python: 2.x and 3.x. The recommended version is 3.x, which is supported by
|
|
|
|
most widely used libraries. Although 2.x is still widely used, `it will not
|
|
|
|
be maintained after January 1, 2020 <https://www.python.org/dev/peps/pep-0373/>`_.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
How many people are using Python?
|
|
|
|
---------------------------------
|
|
|
|
|
2020-06-30 06:51:21 -03:00
|
|
|
There are probably millions of users, though it's difficult to obtain an exact
|
|
|
|
count.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
Python is available for free download, so there are no sales figures, and it's
|
|
|
|
available from many different sites and packaged with many Linux distributions,
|
|
|
|
so download statistics don't tell the whole story either.
|
|
|
|
|
|
|
|
The comp.lang.python newsgroup is very active, but not all Python users post to
|
|
|
|
the group or even read it.
|
|
|
|
|
|
|
|
|
|
|
|
Have any significant projects been done in Python?
|
|
|
|
--------------------------------------------------
|
|
|
|
|
2014-10-29 05:24:54 -03:00
|
|
|
See https://www.python.org/about/success for a list of projects that use Python.
|
2009-10-11 18:25:26 -03:00
|
|
|
Consulting the proceedings for `past Python conferences
|
2014-10-29 05:24:54 -03:00
|
|
|
<https://www.python.org/community/workshops/>`_ will reveal contributions from many
|
2009-10-11 18:25:26 -03:00
|
|
|
different companies and organizations.
|
|
|
|
|
|
|
|
High-profile Python projects include `the Mailman mailing list manager
|
|
|
|
<http://www.list.org>`_ and `the Zope application server
|
|
|
|
<http://www.zope.org>`_. Several Linux distributions, most notably `Red Hat
|
2016-02-26 14:37:12 -04:00
|
|
|
<https://www.redhat.com>`_, have written part or all of their installer and
|
2009-10-11 18:25:26 -03:00
|
|
|
system administration software in Python. Companies that use Python internally
|
|
|
|
include Google, Yahoo, and Lucasfilm Ltd.
|
|
|
|
|
|
|
|
|
|
|
|
What new developments are expected for Python in the future?
|
|
|
|
------------------------------------------------------------
|
|
|
|
|
2014-10-29 04:36:35 -03:00
|
|
|
See https://www.python.org/dev/peps/ for the Python Enhancement Proposals
|
2009-10-11 18:25:26 -03:00
|
|
|
(PEPs). PEPs are design documents describing a suggested new feature for Python,
|
|
|
|
providing a concise technical specification and a rationale. Look for a PEP
|
|
|
|
titled "Python X.Y Release Schedule", where X.Y is a version that hasn't been
|
|
|
|
publicly released yet.
|
|
|
|
|
|
|
|
New development is discussed on `the python-dev mailing list
|
2014-10-29 04:36:35 -03:00
|
|
|
<https://mail.python.org/mailman/listinfo/python-dev/>`_.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
|
|
|
|
Is it reasonable to propose incompatible changes to Python?
|
|
|
|
-----------------------------------------------------------
|
|
|
|
|
|
|
|
In general, no. There are already millions of lines of Python code around the
|
|
|
|
world, so any change in the language that invalidates more than a very small
|
|
|
|
fraction of existing programs has to be frowned upon. Even if you can provide a
|
|
|
|
conversion program, there's still the problem of updating all documentation;
|
|
|
|
many books have been written about Python, and we don't want to invalidate them
|
|
|
|
all at a single stroke.
|
|
|
|
|
|
|
|
Providing a gradual upgrade path is necessary if a feature has to be changed.
|
|
|
|
:pep:`5` describes the procedure followed for introducing backward-incompatible
|
|
|
|
changes while minimizing disruption for users.
|
|
|
|
|
|
|
|
|
|
|
|
Is Python a good language for beginning programmers?
|
|
|
|
----------------------------------------------------
|
|
|
|
|
|
|
|
Yes.
|
|
|
|
|
|
|
|
It is still common to start students with a procedural and statically typed
|
|
|
|
language such as Pascal, C, or a subset of C++ or Java. Students may be better
|
|
|
|
served by learning Python as their first language. Python has a very simple and
|
|
|
|
consistent syntax and a large standard library and, most importantly, using
|
|
|
|
Python in a beginning programming course lets students concentrate on important
|
|
|
|
programming skills such as problem decomposition and data type design. With
|
|
|
|
Python, students can be quickly introduced to basic concepts such as loops and
|
|
|
|
procedures. They can probably even work with user-defined objects in their very
|
|
|
|
first course.
|
|
|
|
|
|
|
|
For a student who has never programmed before, using a statically typed language
|
|
|
|
seems unnatural. It presents additional complexity that the student must master
|
|
|
|
and slows the pace of the course. The students are trying to learn to think
|
|
|
|
like a computer, decompose problems, design consistent interfaces, and
|
|
|
|
encapsulate data. While learning to use a statically typed language is
|
|
|
|
important in the long term, it is not necessarily the best topic to address in
|
|
|
|
the students' first programming course.
|
|
|
|
|
|
|
|
Many other aspects of Python make it a good first language. Like Java, Python
|
|
|
|
has a large standard library so that students can be assigned programming
|
|
|
|
projects very early in the course that *do* something. Assignments aren't
|
|
|
|
restricted to the standard four-function calculator and check balancing
|
|
|
|
programs. By using the standard library, students can gain the satisfaction of
|
|
|
|
working on realistic applications as they learn the fundamentals of programming.
|
|
|
|
Using the standard library also teaches students about code reuse. Third-party
|
|
|
|
modules such as PyGame are also helpful in extending the students' reach.
|
|
|
|
|
|
|
|
Python's interactive interpreter enables students to test language features
|
|
|
|
while they're programming. They can keep a window with the interpreter running
|
|
|
|
while they enter their program's source in another window. If they can't
|
|
|
|
remember the methods for a list, they can do something like this::
|
|
|
|
|
|
|
|
>>> L = []
|
2014-10-06 12:51:09 -03:00
|
|
|
>>> dir(L) # doctest: +NORMALIZE_WHITESPACE
|
|
|
|
['__add__', '__class__', '__contains__', '__delattr__', '__delitem__',
|
|
|
|
'__dir__', '__doc__', '__eq__', '__format__', '__ge__',
|
|
|
|
'__getattribute__', '__getitem__', '__gt__', '__hash__', '__iadd__',
|
|
|
|
'__imul__', '__init__', '__iter__', '__le__', '__len__', '__lt__',
|
|
|
|
'__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__',
|
|
|
|
'__repr__', '__reversed__', '__rmul__', '__setattr__', '__setitem__',
|
|
|
|
'__sizeof__', '__str__', '__subclasshook__', 'append', 'clear',
|
|
|
|
'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove',
|
2009-10-11 18:25:26 -03:00
|
|
|
'reverse', 'sort']
|
2014-10-06 12:51:09 -03:00
|
|
|
>>> [d for d in dir(L) if '__' not in d]
|
|
|
|
['append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']
|
|
|
|
|
2009-10-11 18:25:26 -03:00
|
|
|
>>> help(L.append)
|
|
|
|
Help on built-in function append:
|
2014-10-06 12:51:09 -03:00
|
|
|
<BLANKLINE>
|
2009-10-11 18:25:26 -03:00
|
|
|
append(...)
|
2014-10-06 12:51:09 -03:00
|
|
|
L.append(object) -> None -- append object to end
|
|
|
|
<BLANKLINE>
|
2009-10-11 18:25:26 -03:00
|
|
|
>>> L.append(1)
|
|
|
|
>>> L
|
|
|
|
[1]
|
|
|
|
|
2016-06-15 12:12:49 -03:00
|
|
|
With the interpreter, documentation is never far from the student as they are
|
2009-10-11 18:25:26 -03:00
|
|
|
programming.
|
|
|
|
|
|
|
|
There are also good IDEs for Python. IDLE is a cross-platform IDE for Python
|
|
|
|
that is written in Python using Tkinter. PythonWin is a Windows-specific IDE.
|
|
|
|
Emacs users will be happy to know that there is a very good Python mode for
|
|
|
|
Emacs. All of these programming environments provide syntax highlighting,
|
|
|
|
auto-indenting, and access to the interactive interpreter while coding. Consult
|
2014-03-16 01:13:56 -03:00
|
|
|
`the Python wiki <https://wiki.python.org/moin/PythonEditors>`_ for a full list
|
|
|
|
of Python editing environments.
|
2009-10-11 18:25:26 -03:00
|
|
|
|
|
|
|
If you want to discuss Python's use in education, you may be interested in
|
|
|
|
joining `the edu-sig mailing list
|
2014-10-29 04:36:35 -03:00
|
|
|
<https://www.python.org/community/sigs/current/edu-sig>`_.
|