mirror of
https://github.com/adambard/learnxinyminutes-docs.git
synced 2024-12-24 18:11:38 +00:00
Merge pull request #1489 from evuez/patch-2
[python/en] Add some stuff to lists, tuples, dicts, sets and classes
This commit is contained in:
commit
a3db78c73d
@ -4,6 +4,7 @@ contributors:
|
|||||||
- ["Louie Dinh", "http://ldinh.ca"]
|
- ["Louie Dinh", "http://ldinh.ca"]
|
||||||
- ["Amin Bandali", "http://aminbandali.com"]
|
- ["Amin Bandali", "http://aminbandali.com"]
|
||||||
- ["Andre Polykanine", "https://github.com/Oire"]
|
- ["Andre Polykanine", "https://github.com/Oire"]
|
||||||
|
- ["evuez", "http://github.com/evuez"]
|
||||||
filename: learnpython.py
|
filename: learnpython.py
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -224,6 +225,17 @@ li + other_li # => [1, 2, 3, 4, 5, 6]
|
|||||||
# Concatenate lists with "extend()"
|
# Concatenate lists with "extend()"
|
||||||
li.extend(other_li) # Now li is [1, 2, 3, 4, 5, 6]
|
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) # => 3
|
||||||
|
li.index(7) # Raises a ValueError as 7 is not in the list
|
||||||
|
|
||||||
# Check for existence in a list with "in"
|
# Check for existence in a list with "in"
|
||||||
1 in li # => True
|
1 in li # => True
|
||||||
|
|
||||||
@ -315,6 +327,15 @@ filled_set | other_set # => {1, 2, 3, 4, 5, 6}
|
|||||||
# Do set difference with -
|
# Do set difference with -
|
||||||
{1, 2, 3, 4} - {2, 3, 5} # => {1, 4}
|
{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
|
# Check for existence in a set with in
|
||||||
2 in filled_set # => True
|
2 in filled_set # => True
|
||||||
10 in filled_set # => False
|
10 in filled_set # => False
|
||||||
@ -466,19 +487,19 @@ def pass_all_the_args(*args, **kwargs):
|
|||||||
# Function Scope
|
# Function Scope
|
||||||
x = 5
|
x = 5
|
||||||
|
|
||||||
def setX(num):
|
def set_x(num):
|
||||||
# Local var x not the same as global variable x
|
# Local var x not the same as global variable x
|
||||||
x = num # => 43
|
x = num # => 43
|
||||||
print x # => 43
|
print x # => 43
|
||||||
|
|
||||||
def setGlobalX(num):
|
def set_global_x(num):
|
||||||
global x
|
global x
|
||||||
print x # => 5
|
print x # => 5
|
||||||
x = num # global var x is now set to 6
|
x = num # global var x is now set to 6
|
||||||
print x # => 6
|
print x # => 6
|
||||||
|
|
||||||
setX(43)
|
set_x(43)
|
||||||
setGlobalX(6)
|
set_global_x(6)
|
||||||
|
|
||||||
# Python has first class functions
|
# Python has first class functions
|
||||||
def create_adder(x):
|
def create_adder(x):
|
||||||
@ -522,6 +543,10 @@ class Human(object):
|
|||||||
# Assign the argument to the instance's name attribute
|
# Assign the argument to the instance's name attribute
|
||||||
self.name = name
|
self.name = name
|
||||||
|
|
||||||
|
# Initialize property
|
||||||
|
self.age = 0
|
||||||
|
|
||||||
|
|
||||||
# An instance method. All methods take "self" as the first argument
|
# An instance method. All methods take "self" as the first argument
|
||||||
def say(self, msg):
|
def say(self, msg):
|
||||||
return "{0}: {1}".format(self.name, msg)
|
return "{0}: {1}".format(self.name, msg)
|
||||||
@ -537,6 +562,23 @@ class Human(object):
|
|||||||
def grunt():
|
def grunt():
|
||||||
return "*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
|
# Instantiate a class
|
||||||
i = Human(name="Ian")
|
i = Human(name="Ian")
|
||||||
@ -556,6 +598,16 @@ j.get_species() # => "H. neanderthalensis"
|
|||||||
# Call the static method
|
# Call the static method
|
||||||
Human.grunt() # => "*grunt*"
|
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
|
## 6. Modules
|
||||||
|
@ -5,6 +5,7 @@ contributors:
|
|||||||
- ["Steven Basart", "http://github.com/xksteven"]
|
- ["Steven Basart", "http://github.com/xksteven"]
|
||||||
- ["Andre Polykanine", "https://github.com/Oire"]
|
- ["Andre Polykanine", "https://github.com/Oire"]
|
||||||
- ["Zachary Ferguson", "http://github.com/zfergus2"]
|
- ["Zachary Ferguson", "http://github.com/zfergus2"]
|
||||||
|
- ["evuez", "http://github.com/evuez"]
|
||||||
filename: learnpython3.py
|
filename: learnpython3.py
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -216,6 +217,17 @@ li2 = li[:] # => li2 = [1, 2, 4, 3] but (li2 is li) will result in false.
|
|||||||
# Remove arbitrary elements from a list with "del"
|
# Remove arbitrary elements from a list with "del"
|
||||||
del li[2] # li is now [1, 2, 3]
|
del li[2] # li is now [1, 2, 3]
|
||||||
|
|
||||||
|
# Remove first occurrence of a value
|
||||||
|
li.remove(2) # li is now [1, 3]
|
||||||
|
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] again
|
||||||
|
|
||||||
|
# Get the index of the first item found
|
||||||
|
li.index(2) # => 3
|
||||||
|
li.index(4) # Raises a ValueError as 4 is not in the list
|
||||||
|
|
||||||
# You can add lists
|
# You can add lists
|
||||||
# Note: values for li and for other_li are not modified.
|
# Note: values for li and for other_li are not modified.
|
||||||
li + other_li # => [1, 2, 3, 4, 5, 6]
|
li + other_li # => [1, 2, 3, 4, 5, 6]
|
||||||
@ -249,6 +261,8 @@ tup[:2] # => (1, 2)
|
|||||||
|
|
||||||
# You can unpack tuples (or lists) into variables
|
# 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
|
a, b, c = (1, 2, 3) # a is now 1, b is now 2 and c is now 3
|
||||||
|
# You can also do extended unpacking
|
||||||
|
a, *b, c = (1, 2, 3, 4) # a is now 1, b is now [2, 3] and c is now 4
|
||||||
# Tuples are created by default if you leave out the parentheses
|
# Tuples are created by default if you leave out the parentheses
|
||||||
d, e, f = 4, 5, 6
|
d, e, f = 4, 5, 6
|
||||||
# Now look how easy it is to swap two values
|
# Now look how easy it is to swap two values
|
||||||
@ -306,6 +320,11 @@ filled_dict.update({"four":4}) # => {"one": 1, "two": 2, "three": 3, "four": 4}
|
|||||||
# Remove keys from a dictionary with del
|
# Remove keys from a dictionary with del
|
||||||
del filled_dict["one"] # Removes the key "one" from filled dict
|
del filled_dict["one"] # Removes the key "one" from filled dict
|
||||||
|
|
||||||
|
# From Python 3.5 you can also use the additional unpacking options
|
||||||
|
{'a': 1, **{'b': 2}} # => {'a': 1, 'b': 2}
|
||||||
|
{'a': 1, **{'a': 2}} # => {'a': 2}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Sets store ... well sets
|
# Sets store ... well sets
|
||||||
empty_set = set()
|
empty_set = set()
|
||||||
@ -332,6 +351,15 @@ filled_set | other_set # => {1, 2, 3, 4, 5, 6}
|
|||||||
# Do set difference with -
|
# Do set difference with -
|
||||||
{1, 2, 3, 4} - {2, 3, 5} # => {1, 4}
|
{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
|
# Check for existence in a set with in
|
||||||
2 in filled_set # => True
|
2 in filled_set # => True
|
||||||
10 in filled_set # => False
|
10 in filled_set # => False
|
||||||
@ -439,7 +467,7 @@ with open("myfile.txt") as f:
|
|||||||
|
|
||||||
filled_dict = {"one": 1, "two": 2, "three": 3}
|
filled_dict = {"one": 1, "two": 2, "three": 3}
|
||||||
our_iterable = filled_dict.keys()
|
our_iterable = filled_dict.keys()
|
||||||
print(our_iterable) # => range(1,10). This is an object that implements our Iterable interface
|
print(our_iterable) # => dict_keys(['one', 'two', 'three']). This is an object that implements our Iterable interface.
|
||||||
|
|
||||||
# We can loop over it.
|
# We can loop over it.
|
||||||
for i in our_iterable:
|
for i in our_iterable:
|
||||||
@ -528,19 +556,19 @@ x, y = swap(x, y) # => x = 2, y = 1
|
|||||||
# Function Scope
|
# Function Scope
|
||||||
x = 5
|
x = 5
|
||||||
|
|
||||||
def setX(num):
|
def set_x(num):
|
||||||
# Local var x not the same as global variable x
|
# Local var x not the same as global variable x
|
||||||
x = num # => 43
|
x = num # => 43
|
||||||
print (x) # => 43
|
print (x) # => 43
|
||||||
|
|
||||||
def setGlobalX(num):
|
def set_global_x(num):
|
||||||
global x
|
global x
|
||||||
print (x) # => 5
|
print (x) # => 5
|
||||||
x = num # global var x is now set to 6
|
x = num # global var x is now set to 6
|
||||||
print (x) # => 6
|
print (x) # => 6
|
||||||
|
|
||||||
setX(43)
|
set_x(43)
|
||||||
setGlobalX(6)
|
set_global_x(6)
|
||||||
|
|
||||||
|
|
||||||
# Python has first class functions
|
# Python has first class functions
|
||||||
@ -589,6 +617,9 @@ class Human:
|
|||||||
# Assign the argument to the instance's name attribute
|
# Assign the argument to the instance's name attribute
|
||||||
self.name = name
|
self.name = name
|
||||||
|
|
||||||
|
# Initialize property
|
||||||
|
self.age = 0
|
||||||
|
|
||||||
# An instance method. All methods take "self" as the first argument
|
# An instance method. All methods take "self" as the first argument
|
||||||
def say(self, msg):
|
def say(self, msg):
|
||||||
return "{name}: {message}".format(name=self.name, message=msg)
|
return "{name}: {message}".format(name=self.name, message=msg)
|
||||||
@ -604,6 +635,23 @@ class Human:
|
|||||||
def grunt():
|
def grunt():
|
||||||
return "*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
|
# Instantiate a class
|
||||||
i = Human(name="Ian")
|
i = Human(name="Ian")
|
||||||
@ -623,6 +671,17 @@ j.get_species() # => "H. neanderthalensis"
|
|||||||
# Call the static method
|
# Call the static method
|
||||||
Human.grunt() # => "*grunt*"
|
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
|
## 6. Modules
|
||||||
|
Loading…
Reference in New Issue
Block a user