Python

Getting started

Environment

Interpreter

  • cython
  • jython
  • pypy

Python 2

2.7 ~ jul 2010

print "foo"

<>

u"foo"

class C:
    __metaclass__ = M

except Exception,  e:

Python 3

3.4 ~ mar 2014

print("foo")

!=

"foo"

class C(metaclass=M):

 

except Exception as e:

PIP

$ apt-get install python-pip

$ pip install ansible

$ pip install git+https://github.com/x/y.git@branch

$ pip install ./

http://pypi.python.org

http://rtfd.org

setup.py

#!/usr/bin/env python

import os
import sys
from glob import glob

setup(name='ansible',
      version=__version__,
      description='Radically simple IT automation',
      author=__author__,
      author_email='michael@ansible.com',
      url='http://ansible.com/',
      license='GPLv3',
      install_requires=['paramiko', 'jinja2', "PyYAML", 'setuptools', 'pycrypto >= 2.6'],
      package_dir={ 'ansible': 'lib/ansible' },
      packages=find_packages('lib'),
      package_data={
         '': ['module_utils/*.ps1', 'modules/core/windows/*.ps1', 'modules/extras/windows/*.ps1'],
      },
      scripts=[
         'bin/ansible',
         'bin/ansible-playbook',
         'bin/ansible-pull',
         'bin/ansible-doc',
         'bin/ansible-galaxy',
         'bin/ansible-vault',
      ],
      data_files=[],
)

Virtualenv

$ pip install virtualenvwrapper

$ source /usr/local/bin/virtualenvwrapper.sh

$ pip freeze
virtualenv==1.11.6
virtualenv-clone==0.2.5
virtualenvwrapper==4.3.1

$ mkvirtualenv projectA

(projectA) $ pip install fabric

(projectA) $ pip freeze
Fabric==1.10.0
ecdsa==0.11
paramiko==1.15.1
pycrypto==2.6.1

(projectA) $ deactivate

$ pip freeze
virtualenv==1.11.6
virtualenv-clone==0.2.5
virtualenvwrapper==4.3.1

$ workon projectA

(projectA) $ 

Code

int = 0
string = "foo" + 'bar'
bool = False

def great(name):
    return "Hello %s" % name

class MyObject(ParentA, ParentB):
    """This is my Object
    """

    def __init__(self, foo):
        self.foo = foo

    def a_method(self, default_value, flag = True):
        """Class contructor

        :param default_value:
        :type default_value: str
        :returns: Something
        :rtpye: str
        """
        if flag:
            return self.foo

        return default_value

    def __private(self):
        pass

    def _protected(self):
        pass

    def public(self):
        pass

    @staticmethod
    def static_method(x):
        pass

    @property
    def my_property(self):
        return self._my_property

Doc

def multiply(a, b):
    """
    >>> multiply(4, 3)
    12
    >>> multiply('a', 3)
    'aaa'
    """
    return a * b


if __name__ == "__main__":
    import doctest
    doctest.testmod()
def foo():
    """This is the foo method
    """
    pass

print(foo.__doc__)

Operators

1 + 1 == 2

"A" + "B" == "AB"

"A" * 3 == "AAA"

"Hello %s" % "Sensiolabs" == "Hello Sensiolabs"
"Hello %s %s" % ("John", "Doe") == "Hello John Doe"

isA or isB

isA and isB

"foo bar"[2:5] == "o b"
"foo bar"[-2] == "a"
"foo bar"[4:] == " bar"
"foo bar"[:-1] == "foo ba"
my_tupple = ("A", "B")

Array

my_set = set({"a": "A", "b": "B"})
my_dict = {"a": "A", "b": "B"}
my_dict = dict([("a", "A"), ("b", "B")])
my_dict["c"] = "C"
my_list = ["A", "B"]
my_list = list(my_tupple)
my_list.append("C")

for

lst = range(10)


doubled = [ num * 2 for num in lst ]

even = [ x for x in lst if x % 2 == 1 ]

odd_or_negative = [ x if not x % 2 else -x for x in lst ]

byte_sizes = [ "%i => %i" % (j, 256**j-1) for j in [ 1 << i for i in range(6) ] ]
for item in my_tupple:
    print(item)

for key in my_dict.keys():
    print(key)

for value in my_dict.values():
    print(value)

for (key, value) in my_dict.items():
    print(key, value)
square = lambda x: x**2


sorted_users = sorted(users, key=lambda user: user.age) 


fib = lambda n: n if n < 2 else fib(n-1) + fib(n-2)


def make_printer(msg):
    def printer(msg=msg):
        print msg
    return printer

printer = make_printer("Foo!")
printer() 

lambda & Closures

Modules

# main.py
import module_a
import module_b
import os
print(os.path.dirname(__file__))

from os.path import dirname
print(dirname(__file__))
$ tree
.
├── main.py
├── module_a
│   └── __init__.py
└── module_b.py
├── manage.py
└── mysite
    ├── __init__.py
    ├── settings.py
    ├── models.py
    ├── urls.py
    └── views.py
├── manage.py
└── mysite
    ├── __init__.py
    ├── settings.py
    ├── models
    │   ├── __init__.py
    │   ├── user.py
    │   └── catalog.py
    ├── urls.py
    └── views.py

NAMED Parameter

def info(object, spacing=10, collapse=1):
    pass

info(object, collapse=2)


b = Blog(name='Foo', tagline='Bar')

Entry.objects.filter(
    headline__startswith='What'
).exclude(
    pub_date__gte=datetime.date.today()
).filter(
    pub_date__gte=datetime(2005, 1, 30)
)

*args **kwargs

def foo(arg1, *args, **kwargs):
    print(arg1)
    print(args)
    print(kwargs)

foo("A", "B", "C", bar = "D", baz = "E")

# A
# ('B', 'C')
# {'baz': 'E', 'bar': 'D'}
def foo(arg1, arg2):
    pass

args = ["A", "B"]
foo(*args)

kwargs = {"arg1": "C", "arg2": "D"}
foo(**kwargs)

Decorator

def log_console(function):
    def wrapper(*args, **kwargs):
        result = function(*args, **kwargs)
        print('Call func "{0}" with {1} and {2} returns: {3}'.format(
            function.__name__, args, kwargs, result))

        return result

    return wrapper

@log_console
def addition(a, b):
    return a+b

addition(1, 2)
# log_console(addition)(1, 2)

# Call func "addition" with (1, 2) and {} returns: 3

Context Manager

@contextmanager
def transaction(con):
    con.begin_transaction()
    try:
        yield con
        con.commit()
    except Exception as e:
        con.rollback()
        raise

with transaction(con) as con:
    con.execute(sql)

Method override

def my_len(string):
    return 42


print(len("hello")) # 5
len = my_len
print(len("hello")) # 42
from mock import mock_open, patch
m = mock_open()
with patch('{}.open'.format(__name__), m, create=True):
   with open('foo', 'w') as h:
       h.write('some stuff')

m.assert_called_once_with('foo', 'w')
handle = m()
handle.write.assert_called_once_with('some stuff')

operator overloading

from functools import total_ordering

@total_ordering
class Person():
    def __init__(self, firstname, lastname):
        self.firstname = firstname
        self.lastname = lastname

    def __eq__(self, other):
        return (self.lastname, self.firstname) == (other.lastname, other.firstname)

    def __lt__(self, other):
        return (self.lastname, self.firstname) < (other.lastname, other.firstname)

print(Person("John", "Doe") == Person("Jane", "Doe"))
print(Person("John", "Doe") < Person("Jane", "Doe"))
print(Person("John", "Doe") > Person("Jane", "Doe"))
print(Person("John", "Doe") != Person("Jane", "Doe"))

# False
# False
# True
# True

Metaclass

class PropertyMetaclass(type):
    def __init__(cls, name, bases, dict):
        type.__init__(cls, name, bases, dict)
        props = getattr(cls, '__properties__', {})
        for name, default in props.items():
            type(cls).create_property(cls, name, default)

    def attr_name(cls, prop):
        return '_%s'%prop

    def create_property(cls, name, default):
        getter=lambda self: getattr(self, cls.attr_name(name))
        setter=lambda self, value: setattr(self, cls.attr_name(name), value)
        prop=property(getter, setter, None, None)
        setattr(cls, cls.attr_name(name), default)
        setattr(cls, name, prop)

class Book(object, metaclass = PropertyMetaclass):
    __properties__ = {
        'author': '[unknown title]',
        'title': '[unknown author]'
    }

book = Book()
book.title = "I love python"
print(book.author)

Questions ?

Made with Slides.com