diff options
| author | C. Bess <cbess@company.com> | 2015-11-09 17:55:53 -0600 | 
|---|---|---|
| committer | C. Bess <cbess@company.com> | 2015-11-09 17:55:53 -0600 | 
| commit | df0992d72c2a28f140e6ff9681c505f36e19249a (patch) | |
| tree | 508aa3abe4c25b957dca442560d9c95c9b1fc97a /python.html.markdown | |
| parent | afc5ea14654e0e9cd11c7ef1b672639d12418bad (diff) | |
| parent | c460e1fafa0e9b4edc6a5cb35b970bb5cc030a81 (diff) | |
Merge remote-tracking branch 'adambard/master'
Conflicts:
	swift.html.markdown
Diffstat (limited to 'python.html.markdown')
| -rw-r--r-- | python.html.markdown | 193 | 
1 files changed, 149 insertions, 44 deletions
| diff --git a/python.html.markdown b/python.html.markdown index 53381f32..f8f712d3 100644 --- a/python.html.markdown +++ b/python.html.markdown @@ -4,6 +4,7 @@ contributors:      - ["Louie Dinh", "http://ldinh.ca"]      - ["Amin Bandali", "http://aminbandali.com"]      - ["Andre Polykanine", "https://github.com/Oire"] +    - ["evuez", "http://github.com/evuez"]  filename: learnpython.py  --- @@ -14,7 +15,13 @@ executable pseudocode.  Feedback would be highly appreciated! You can reach me at [@louiedinh](http://twitter.com/louiedinh) or louiedinh [at] [google's email service]  Note: This article applies to Python 2.7 specifically, but should be applicable -to Python 2.x. For Python 3.x, take a look at the Python 3 tutorial. +to Python 2.x. Python 2.7 is reaching end of life and will stop being maintained in 2020, +it is though recommended to start learning Python with Python 3. +For Python 3.x, take a look at the [Python 3 tutorial](http://learnxinyminutes.com/docs/python3/). + +It is also possible to write Python code which is compatible with Python 2.7 and 3.x at the same time, +using Python [`__future__` imports](https://docs.python.org/2/library/__future__.html). `__future__` imports +allow you to write Python 3 code that will run on Python 2, so check out the Python 3 tutorial.  ```python @@ -46,12 +53,18 @@ to Python 2.x. For Python 3.x, take a look at the Python 3 tutorial.  2.0     # This is a float  11.0 / 4.0  # => 2.75 ahhh...much better -# Result of integer division truncated down both for positive and negative.  +# Result of integer division truncated down both for positive and negative.  5 // 3     # => 1  5.0 // 3.0 # => 1.0 # works on floats too  -5 // 3  # => -2  -5.0 // 3.0 # => -2.0 +# Note that we can also import division module(Section 6 Modules) +# to carry out normal division with just one '/'. +from __future__ import division +11/4    # => 2.75  ...normal division +11//4   # => 2 ...floored division +  # Modulo operation  7 % 3 # => 1 @@ -101,6 +114,8 @@ not False  # => True  # Strings can be added too!  "Hello " + "world!"  # => "Hello world!" +# Strings can be added without using '+' +"Hello " "world!"  # => "Hello world!"  # ... or multiplied  "Hello" * 3  # => "HelloHelloHello" @@ -108,11 +123,16 @@ not False  # => True  # A string can be treated like a list of characters  "This is a string"[0]  # => 'T' -# % can be used to format strings, like this: -"%s can be %s" % ("strings", "interpolated") +#String formatting with % +#Even though the % string operator will be deprecated on Python 3.1 and removed  +#later at some time, it may still be good to know how it works. +x = 'apple' +y = 'lemon' +z = "The items in the basket are %s and %s" % (x,y)  # A newer way to format strings is the format method.  # This method is the preferred way +"{} is a {}".format("This", "placeholder")  "{0} can be {1}".format("strings", "formatted")  # You can use keywords if you don't want to count.  "{name} wants to eat {food}".format(name="Bob", food="lasagna") @@ -129,8 +149,16 @@ None is None  # => True  # very useful when dealing with primitive values, but is  # very useful when dealing with objects. -# None, 0, and empty strings/lists all evaluate to False. -# All other values are True +# Any object can be used in a Boolean context. +# The following values are considered falsey: +#    - None +#    - zero of any numeric type (e.g., 0, 0L, 0.0, 0j) +#    - empty sequences (e.g., '', (), []) +#    - empty containers (e.g., {}, set()) +#    - instances of user-defined classes meeting certain conditions +#      see: https://docs.python.org/2/reference/datamodel.html#object.__nonzero__ +# +# All other values are truthy (using the bool() function on them returns True).  bool(0)  # => False  bool("")  # => False @@ -139,12 +167,14 @@ bool("")  # => False  ## 2. Variables and Collections  #################################################### -# Python has a print statement, in all 2.x versions but removed from 3. -print "I'm Python. Nice to meet you!" -# Python also has a print function, available in versions 2.7 and 3... -# but for 2.7 you need to add the import (uncommented): -# from __future__ import print_function -print("I'm also Python! ") +# Python has a print statement +print "I'm Python. Nice to meet you!" # => I'm Python. Nice to meet you! + +# Simple way to get input data from console +input_string_var = raw_input("Enter some data: ") # Returns the data as a string +input_var = input("Enter some data: ") # Evaluates the data as python code +# Warning: Caution is recommended for input() method usage +# Note: In python 3, input() is deprecated and raw_input() is renamed to input()  # No need to declare variables before assigning to them.  some_var = 5    # Convention is to use lower_case_with_underscores @@ -155,6 +185,7 @@ some_var  # => 5  some_other_var  # Raises a name error  # if can be used as an expression +# Equivalent of C's '?:' ternary operator  "yahoo!" if 3 > 2 else 2  # => "yahoo!"  # Lists store sequences @@ -193,7 +224,7 @@ li[2:]  # => [4, 3]  li[:3]  # => [1, 2, 4]  # Select every second entry  li[::2]   # =>[1, 4] -# Revert the list +# Reverse a copy of the list  li[::-1]   # => [3, 4, 2, 1]  # Use any combination of these to make advanced slices  # li[start:end:step] @@ -208,6 +239,17 @@ li + other_li   # => [1, 2, 3, 4, 5, 6]  # Concatenate lists with "extend()"  li.extend(other_li)   # Now li is [1, 2, 3, 4, 5, 6] +# Remove first occurrence of a value +li.remove(2)  # li is now [1, 3, 4, 5, 6] +li.remove(2)  # Raises a ValueError as 2 is not in the list + +# Insert an element at a specific index +li.insert(1, 2)  # li is now [1, 2, 3, 4, 5, 6] again + +# Get the index of the first item found +li.index(2)  # => 1 +li.index(7)  # Raises a ValueError as 7 is not in the list +  # Check for existence in a list with "in"  1 in li   # => True @@ -228,8 +270,9 @@ tup[:2]   # => (1, 2)  # You can unpack tuples (or lists) into variables  a, b, c = (1, 2, 3)     # a is now 1, b is now 2 and c is now 3 +d, e, f = 4, 5, 6       # you can leave out the parentheses  # Tuples are created by default if you leave out the parentheses -d, e, f = 4, 5, 6 +g = 4, 5, 6             # => (4, 5, 6)  # Now look how easy it is to swap two values  e, d = d, e     # d is now 5 and e is now 4 @@ -264,7 +307,7 @@ filled_dict.get("four")   # => None  # The get method supports a default argument when the value is missing  filled_dict.get("one", 4)   # => 1  filled_dict.get("four", 4)   # => 4 -# note that filled_dict.get("four") is still => 4 +# note that filled_dict.get("four") is still => None  # (get doesn't set the value in the dictionary)  # set the value of a key with a syntax similar to lists @@ -299,6 +342,15 @@ filled_set | other_set   # => {1, 2, 3, 4, 5, 6}  # Do set difference with -  {1, 2, 3, 4} - {2, 3, 5}   # => {1, 4} +# Do set symmetric difference with ^ +{1, 2, 3, 4} ^ {2, 3, 5}  # => {1, 4, 5} + +# Check if set on the left is a superset of set on the right +{1, 2} >= {1, 2, 3} # => False + +# Check if set on the left is a subset of set on the right +{1, 2} <= {1, 2, 3} # => True +  # Check for existence in a set with in  2 in filled_set   # => True  10 in filled_set   # => False @@ -314,11 +366,11 @@ some_var = 5  # Here is an if statement. Indentation is significant in python!  # prints "some_var is smaller than 10"  if some_var > 10: -    print("some_var is totally bigger than 10.") +    print "some_var is totally bigger than 10."  elif some_var < 10:    # This elif clause is optional. -    print("some_var is smaller than 10.") +    print "some_var is smaller than 10."  else:           # This is optional too. -    print("some_var is indeed 10.") +    print "some_var is indeed 10."  """ @@ -329,8 +381,8 @@ prints:      mouse is a mammal  """  for animal in ["dog", "cat", "mouse"]: -    # You can use % to interpolate formatted strings -    print("%s is a mammal" % animal) +    # You can use {0} to interpolate formatted strings. (See above.) +    print "{0} is a mammal".format(animal)  """  "range(number)" returns a list of numbers @@ -342,7 +394,19 @@ prints:      3  """  for i in range(4): -    print(i) +    print i + +""" +"range(lower, upper)" returns a list of numbers +from the lower number to the upper number +prints: +    4 +    5 +    6 +    7 +""" +for i in range(4, 8): +    print i  """  While loops go until a condition is no longer met. @@ -354,7 +418,7 @@ prints:  """  x = 0  while x < 4: -    print(x) +    print x      x += 1  # Shorthand for x = x + 1  # Handle exceptions with a try/except block @@ -369,7 +433,13 @@ except (TypeError, NameError):      pass    # Multiple exceptions can be handled together, if required.  else:   # Optional clause to the try/except block. Must follow all except blocks      print "All good!"   # Runs only if the code in try raises no exceptions +finally: #  Execute under all circumstances +    print "We can clean up resources here" +# Instead of try/finally to cleanup resources you can use a with statement +with open("myfile.txt") as f: +    for line in f: +        print line  ####################################################  ## 4. Functions @@ -377,7 +447,7 @@ else:   # Optional clause to the try/except block. Must follow all except blocks  # Use "def" to create new functions  def add(x, y): -    print("x is %s and y is %s" % (x, y)) +    print "x is {0} and y is {1}".format(x, y)      return x + y    # Return values with a return statement  # Calling functions with parameters @@ -388,7 +458,7 @@ add(y=6, x=5)   # Keyword arguments can arrive in any order.  # You can define functions that take a variable number of -# positional args, which will be interpreted as a tuple if you do not use the * +# positional args, which will be interpreted as a tuple by using *  def varargs(*args):      return args @@ -396,7 +466,7 @@ varargs(1, 2, 3)   # => (1, 2, 3)  # You can define functions that take a variable number of -# keyword args, as well, which will be interpreted as a map if you do not use ** +# keyword args, as well, which will be interpreted as a dict by using **  def keyword_args(**kwargs):      return kwargs @@ -406,8 +476,8 @@ keyword_args(big="foot", loch="ness")   # => {"big": "foot", "loch": "ness"}  # You can do both at once, if you like  def all_the_args(*args, **kwargs): -    print(args) -    print(kwargs) +    print args +    print kwargs  """  all_the_args(1, 2, a=3, b=4) prints:      (1, 2) @@ -429,22 +499,22 @@ def pass_all_the_args(*args, **kwargs):      print varargs(*args)      print keyword_args(**kwargs) -# Function Scope                                                                 +# Function Scope  x = 5 -def setX(num): +def set_x(num):      # Local var x not the same as global variable x      x = num # => 43      print x # => 43 -     -def setGlobalX(num): + +def set_global_x(num):      global x      print x # => 5      x = num # global var x is now set to 6      print x # => 6 -setX(43) -setGlobalX(6) +set_x(43) +set_global_x(6)  # Python has first class functions  def create_adder(x): @@ -457,9 +527,12 @@ add_10(3)   # => 13  # There are also anonymous functions  (lambda x: x > 2)(3)   # => True +(lambda x, y: x ** 2 + y ** 2)(2, 1) # => 5  # There are built-in higher order functions  map(add_10, [1, 2, 3])   # => [11, 12, 13] +map(max, [1, 2, 3], [4, 2, 1])   # => [4, 2, 3] +  filter(lambda x: x > 5, [3, 4, 5, 6, 7])   # => [6, 7]  # We can use list comprehensions for nice maps and filters @@ -485,9 +558,13 @@ class Human(object):          # Assign the argument to the instance's name attribute          self.name = name +        # Initialize property +        self.age = 0 + +      # An instance method. All methods take "self" as the first argument      def say(self, msg): -        return "%s: %s" % (self.name, msg) +        return "{0}: {1}".format(self.name, msg)      # A class method is shared among all instances      # They are called with the calling class as the first argument @@ -500,13 +577,30 @@ class Human(object):      def grunt():          return "*grunt*" +    # A property is just like a getter. +    # It turns the method age() into an read-only attribute +    # of the same name. +    @property +    def age(self): +        return self._age + +    # This allows the property to be set +    @age.setter +    def age(self, age): +        self._age = age + +    # This allows the property to be deleted +    @age.deleter +    def age(self): +        del self._age +  # Instantiate a class  i = Human(name="Ian") -print(i.say("hi"))     # prints out "Ian: hi" +print i.say("hi")     # prints out "Ian: hi"  j = Human("Joel") -print(j.say("hello"))  # prints out "Joel: hello" +print j.say("hello")  # prints out "Joel: hello"  # Call our class method  i.get_species()   # => "H. sapiens" @@ -519,6 +613,16 @@ j.get_species()   # => "H. neanderthalensis"  # Call the static method  Human.grunt()   # => "*grunt*" +# Update the property +i.age = 42 + +# Get the property +i.age # => 42 + +# Delete the property +del i.age +i.age  # => raises an AttributeError +  ####################################################  ## 6. Modules @@ -526,12 +630,12 @@ Human.grunt()   # => "*grunt*"  # You can import modules  import math -print(math.sqrt(16))  # => 4 +print math.sqrt(16)  # => 4  # You can get specific functions from a module  from math import ceil, floor -print(ceil(3.7))  # => 4.0 -print(floor(3.7))   # => 3.0 +print ceil(3.7)  # => 4.0 +print floor(3.7)   # => 3.0  # You can import all functions from a module.  # Warning: this is not recommended @@ -577,7 +681,7 @@ xrange_ = xrange(1, 900000000)  # will double all numbers until a result >=30 found  for i in double_numbers(xrange_): -    print(i) +    print i      if i >= 30:          break @@ -606,24 +710,25 @@ def say(say_please=False):      return msg, say_please -print(say())  # Can you buy me a beer? -print(say(say_please=True))  # Can you buy me a beer? Please! I am poor :( +print say()  # Can you buy me a beer? +print say(say_please=True)  # Can you buy me a beer? Please! I am poor :(  ```  ## Ready For More?  ### Free Online +* [Automate the Boring Stuff with Python](https://automatetheboringstuff.com)  * [Learn Python The Hard Way](http://learnpythonthehardway.org/book/)  * [Dive Into Python](http://www.diveintopython.net/) -* [The Official Docs](http://docs.python.org/2.6/) +* [The Official Docs](http://docs.python.org/2/)  * [Hitchhiker's Guide to Python](http://docs.python-guide.org/en/latest/)  * [Python Module of the Week](http://pymotw.com/2/)  * [A Crash Course in Python for Scientists](http://nbviewer.ipython.org/5920182) +* [First Steps With Python](https://realpython.com/learn/python-first-steps/)  ### Dead Tree  * [Programming Python](http://www.amazon.com/gp/product/0596158106/ref=as_li_qf_sp_asin_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=0596158106&linkCode=as2&tag=homebits04-20)  * [Dive Into Python](http://www.amazon.com/gp/product/1441413022/ref=as_li_tf_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=1441413022&linkCode=as2&tag=homebits04-20)  * [Python Essential Reference](http://www.amazon.com/gp/product/0672329786/ref=as_li_tf_tl?ie=UTF8&camp=1789&creative=9325&creativeASIN=0672329786&linkCode=as2&tag=homebits04-20) - | 
