tuples.rst
author nishanth
Fri, 17 Sep 2010 14:28:52 +0530
changeset 150 234b393cbc85
child 153 22521a1d6841
permissions -rw-r--r--
initial commit tuples
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
150
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     1
Hello friends and welcome to the tutorial on Tuples
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     2
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     3
{{{ Show the slide containing title }}}
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     4
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     5
{{{ Show the slide containing the outline slide }}}
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     6
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     7
In this tutorial, we shall learn
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     8
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
     9
 * what are tuples
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    10
 * their similarities and dissimilarities with lists
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    11
 * why are they needed
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    12
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    13
Let`s get started by defining a tuple. A tuple is defined by enclosing
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    14
parantheses around a sequence of items seperated by commas. It is similar to
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    15
defining a list except that parantheses are used instead of square brackets.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    16
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    17
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    18
    t = (1, 2.5, "hello", -4, "world", 1.24, 5)
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    19
    t
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    20
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    21
defines a tuple. The items in the tuple are indexed using numbers and can be 
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    22
accessed by using their position.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    23
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    24
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    25
    t[3]
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    26
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    27
prints -4 which is the fourth item of the tuple.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    28
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    29
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    30
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    31
    t[1:5:2]
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    32
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    33
prints the corresponding slice
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    34
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    35
This is the behaviour similar as to lists. But the difference can be seen when
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    36
we try to change an element in the tuple.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    37
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    38
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    39
    t[2] = "Hello"
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    40
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    41
We can see that, it raises an error saying tuple does not support item
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    42
assignment. It only implies that tuples are immutable or in simple words,
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    43
tuples cannot be changed.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    44
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    45
But what is the use of tuples!!!
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    46
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    47
We shall understand that soon. But let us look at a simple problem of swapping
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    48
values.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    49
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    50
{{{ Pause here and try out the following exercises }}}
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    51
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    52
%% 1 %% a = 5 and b = 7. swap the values of a and b
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    53
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    54
{{{ continue from paused state }}}
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    55
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    56
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    57
    a = 5
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    58
    b = 7
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    59
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    60
    a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    61
    b
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    62
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    63
We define the two values
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    64
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    65
    temp = a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    66
    a = b
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    67
    b = temp
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    68
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    69
    a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    70
    b
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    71
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    72
This is the traditional approach
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    73
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    74
Now let us do it the python way
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    75
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    76
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    77
    a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    78
    b
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    79
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    80
    a, b = b, a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    81
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    82
    a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    83
    b
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    84
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    85
We see that the values are swapped.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    86
This idiom works for different datatypes also.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    87
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    88
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    89
    a = 2.5
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    90
    b = "hello"
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    91
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    92
    a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    93
    b
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    94
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    95
Moreover this type of behaviour is straight forward and what you would expect
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    96
should happen naturally.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    97
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    98
This is possible because of the immutability of tuples. This process is called
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
    99
tuple packing and unpacking.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   100
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   101
Let us first see what is tuple packing. Type
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   102
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   103
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   104
    5,
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   105
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   106
What we see is a tuple with one element.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   107
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   108
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   109
    5, "hello", 2.5
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   110
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   111
Now it is a tuple with two elements.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   112
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   113
So when we are actually typing two or more elements seperated by commas, those
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   114
elements are packed and a tuple is made from them.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   115
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   116
When you type
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   117
::
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   118
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   119
    a, b = b, a
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   120
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   121
First the values of b and a are packed into a tuple on the right side and then
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   122
unpacked into the variables a and b.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   123
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   124
Immutability of tuples ensures that the values are not changed during the
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   125
packing and unpacking.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   126
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   127
{{{ Show summary slide }}}
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   128
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   129
This brings us to the end of the tutorial.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   130
we have learnt
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   131
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   132
 * How to define tuples
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   133
 * The similarities of tuples with lists, like indexing and iterability
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   134
 * The immutability of tuples
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   135
 * The value swapping idiom in Python
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   136
 * packing and unpacking of tuples
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   137
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   138
{{{ Show the "sponsored by FOSSEE" slide }}}
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   139
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   140
#[Nishanth]: Will add this line after all of us fix on one.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   141
This tutorial was created as a part of FOSSEE project, NME ICT, MHRD India
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   142
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   143
Hope you have enjoyed and found it useful.
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   144
Thankyou
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   145
 
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   146
.. Author              : Nishanth
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   147
   Internal Reviewer 1 : 
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   148
   Internal Reviewer 2 : 
234b393cbc85 initial commit tuples
nishanth
parents:
diff changeset
   149
   External Reviewer   :