Wednesday, January 26, 2011

python django working of object copy technique

python django working of object copy technique

class MyClass:

def __init__(self, name):
self.amount = 100
self.name = name

def test(self):
print "test"


m1 = MyClass('SAJU')

print "\n-------m1---------", m1
print "\n--------dir(m1)----------", dir(m1)
print "\n--------vars(m1)----------", vars(m1)
print "\n---------m1.__dict__-----------------", m1.__dict__
print "\n----------m1.__class__.__name__----------------", m1.__class__.__name__
print "\n===============================================1"


class EmptyClass:
pass

e1 = EmptyClass()

print "\n-------e1---------", e1
print "\n--------dir(e1)----------", dir(e1)
print "\n--------vars(e1)----------", vars(e1)
print "\n---------e1.__dict__-----------------", e1.__dict__
print "\n----------e1.__class__.__name__----------------", e1.__class__.__name__
print "\n-------isinstance(e1, EmptyClass)--------", isinstance(e1, EmptyClass)
print "\n-------isinstance(e1, MyClass)--------", isinstance(e1, MyClass)
print "\n===============================================2"

e1.__class__ = m1.__class__

print "\n-------e1---------", e1
print "\n--------dir(e1)----------", dir(e1)
print "\n--------vars(e1)----------", vars(e1)
print "\n---------e1.__dict__-----------------", e1.__dict__
print "\n----------e1.__class__.__name__----------------", e1.__class__.__name__
print "\n-------isinstance(e1, EmptyClass)--------", isinstance(e1, EmptyClass)
print "\n-------isinstance(e1, MyClass)--------", isinstance(e1, MyClass)
print "\n===============================================3"

e1.__dict__.update(m1.__dict__)

print "\n-------e1---------", e1
print "\n--------dir(e1)----------", dir(e1)
print "\n--------vars(e1)----------", vars(e1)
print "\n---------e1.__dict__-----------------", e1.__dict__
print "\n----------e1.__class__.__name__----------------", e1.__class__.__name__
print "\n-------isinstance(e1, EmptyClass)--------", isinstance(e1, EmptyClass)
print "\n-------isinstance(e1, MyClass)--------", isinstance(e1, MyClass)
print "\n===============================================4"



OUTPUT
=======
-------m1--------- <__main__.myclass>

--------dir(m1)---------- ['__doc__', '__init__', '__module__', 'amount', 'name', 'test']

--------vars(m1)---------- {'amount': 100, 'name': 'SAJU'}

---------m1.__dict__----------------- {'amount': 100, 'name': 'SAJU'}

----------m1.__class__.__name__---------------- MyClass

===============================================1

-------e1--------- <__main__.emptyclass>

--------dir(e1)---------- ['__doc__', '__module__']

--------vars(e1)---------- {}

---------e1.__dict__----------------- {}

----------e1.__class__.__name__---------------- EmptyClass

-------isinstance(e1, EmptyClass)-------- True

-------isinstance(e1, MyClass)-------- False

===============================================2

-------e1--------- <__main__.myclass>

--------dir(e1)---------- ['__doc__', '__init__', '__module__', 'test']

--------vars(e1)---------- {}

---------e1.__dict__----------------- {}

----------e1.__class__.__name__---------------- MyClass

-------isinstance(e1, EmptyClass)-------- False

-------isinstance(e1, MyClass)-------- True

===============================================3

-------e1--------- <__main__.myclass>

--------dir(e1)---------- ['__doc__', '__init__', '__module__', 'amount', 'name', 'test']

--------vars(e1)---------- {'amount': 100, 'name': 'SAJU'}

---------e1.__dict__----------------- {'amount': 100, 'name': 'SAJU'}

----------e1.__class__.__name__---------------- MyClass

-------isinstance(e1, EmptyClass)-------- False

-------isinstance(e1, MyClass)-------- True

===============================================4

python django howto class name as string

python django how to get class name of an object as string


>>> l = []
>>>
>>> l.__class__.__name__
'list'
===================
>>> t = ()
>>>
>>> t.__class__.__name__
'tuple'
===================
>>> d = {}
>>>
>>> d.__class__.__name__
'dict'
===================
>>> i = int(4)
>>>
>>> i
4
>>> i.__class__.__name__
'int'
===================
>>> f = float(4)
>>>
>>> f
4.0
>>>
>>> f.__class__.__name__
'float'
-------------------------
>>> class Test:
... pass
...
>>>
>>>
>>> t = Test()
>>>
>>> t.__class__.__name__
'Test'
===================

main uses of python __class__

main uses of python __class__

>>> l = [2,4]

>>> l
[2, 4]

>>> l.__class__
type 'list'>

>>> l2 = l.__class__()

>>> l2
[]

>>> l.__class__.__name__
'list'

=====================

>>> l = [2,4]

>>> l
[2, 4]

* Return class (class object) of object l.

>>> l.__class__
type 'list'>

* Creating object of that class (class object) by putting "()" at the end.

>>> l2 = l.__class__()

>>> l2
[]

* To get class name of a python object

>>> l.__class__.__name__
'list'

===================== following are equal

>>> l.__class__
type 'list'>

>>> type(l)
type 'list'>

===================== following are equal

>>> l2 = l.__class__()
>>> l2
[]

>>> l2 = type(l)()
>>> l2
[]

=====================

* You can get the class (class object) of any object by calling "type" on it.

>>> type(l)
type 'list'>

* we can create object of that class (class object) by putting "()" at the end.

>>> lt = type(l)

>>> lt
type 'list'>

>>> lt() <---------"()" at the end.
[]

=====================

Saturday, January 22, 2011

python defining special methods __eq__ and __le__ on a class

python defining special methods __eq__ and __le__ on a class

class A:

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

def __add__(self, second_num):
return self.num + second_num

def __eq__(self, second_num):
if self.num == second_num:
print "\nNumbers are equal"
else:
print "\nNumbers are not equal"

def __le__(self, second_num):
if self.num <= second_num:
print "\n"+str(self.num)+" is less than or equal to "+str(second_num)
else:
print "\n"+str(self.num)+" is grater than "+str(second_num)

a1 = A(10)

print "-------a1 + 10-------", a1 + 40

print "-------a1 == 10-------", a1 == 10

print "-------a1 == 10-------", a1 == 20

print "-------a1 <= 30 -------", a1 <= 30

print "-------a1 <= 5 -------", a1 <= 5



OUTPUT
=======
-------a1 + 10------- 50
-------a1 == 10-------
Numbers are equal
None
-------a1 == 10-------
Numbers are not equal
None
-------a1 <= 30 -------
10 is less than or equal to 30
None
-------a1 <= 5 -------
10 is grater than 5
None

python defining special method __add__ on a class

python defining special method __add__ on a class

======================== 1


class A:

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

def __add__(self, second_num):
return self.num + second_num


a1 = A(10)

print "-------a1 + 10-------", a1 + 40
print "-------a1 + a1-------", a1 + a1


OUTPUT
=======
-------a1 + 10------- 50 <--------
-------a1 + a1-------
Traceback (most recent call last):
File "sp.py", line 16, in
print "-------a1 + a1-------", a1 + a1
File "sp.py", line 10, in __add__
return self.num + second_num
TypeError: unsupported operand type(s) for +: 'int' and 'instance'


======================== 2

class A:

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

def __add__(self, second_object):
return self.num + second_object.num


a1 = A(10)

print "-------a1 + a1-------", a1 + a1
print "-------a1 + 10-------", a1 + 40


OUTPUT
=======
-------a1 + a1------- 20 <--------
-------a1 + 10-------
Traceback (most recent call last):
File "sp.py", line 16, in
print "-------a1 + 10-------", a1 + 40
File "sp.py", line 10, in __add__
return self.num + second_object.num
AttributeError: 'int' object has no attribute 'num'



======================== 3

class a:
def __init__(self):
pass

a1 = a()

print "-------a1 + a1-------", a1 + a1


OUTPUT
========
test@saju-laptop:~/Desktop$ python sp.py
-------a1 + a1-------
Traceback (most recent call last):
File "sp.py", line 10, in
print "-------a1 + a1-------", a1 + a1
TypeError: unsupported operand type(s) for +: 'instance' and 'instance'


======================== 4

class A:
def __init__(self):
pass

def __add__(self, second_item):
print "\n-------in------__add__-------"
print "\n-------first item-------", self
print "\n-------second item------", second_item
#Note: Here items first and second are same(same object 'a1' of class 'A')

a1 = A()

print "--------a1---------", a1

print "\n\***********\n"

print "-------a1 + a1-------", a1 + a1

print "\n\***********\n"

print "---------a1.__add__(a1)------------", a1.__add__(a1)

#Note: Here "a1 + a1" and "a1.__add__(a1)" are same.




OUTPUT
=======
--------a1--------- <__main__.a>

\***********

-------a1 + a1-------
-------in------__add__-------

-------first item------- <__main__.a>

-------second item------ <__main__.a>
None

\***********

---------a1.__add__(a1)------------
-------in------__add__-------

-------first item------- <__main__.a>

-------second item------ <__main__.a>
None


======================== 5

class A:

def __init__(self):
pass

def __add__(self, second_item):
print "\n-------in------__add__-------"
print "\n-------first item-------", self
print "\n-------second item------", second_item
#Note: Here items first 'a1' and second 'a2' are different

a1 = A()
a2 = A()

print "--------a1---------", a1
print "--------a2---------", a2

print "\n\***********\n"

print "-------a1 + a2-------", a1 + a2

print "\n\***********\n"

print "---------a1.__add__(a2)------------", a1.__add__(a2)

#Here "a1 + a2" and "a1.__add__(a2)" are same.


OUTPUT
=======
--------a1--------- <__main__.a>
--------a2--------- <__main__.a>

\***********

-------a1 + a2-------
-------in------__add__-------

-------first item------- <__main__.a>

-------second item------ <__main__.a>
None

\***********

---------a1.__add__(a2)------------
-------in------__add__-------

-------first item------- <__main__.a>

-------second item------ <__main__.a>
None


========================

Friday, January 21, 2011

python django defining __getitem__ on a class

python django defining __getitem__ on a class

# defining __getitem__ on a class make it iterable in python?
# cb[0] is the same as cb.__getitem__(0)

#############################################1

class Test3:

Data = {'name':'saju', 'sex':'male'}

def __init__(self):
print "----in----__init__----"

def __getitem__(self, item1):
return self.Data[item1]


t3 = Test3()
print t3['name']
print t3['sex']


# OUTPUT
# ======
# ----in----__init__----
# saju
# male

#############################################2

class Test1:

def __init__(self):
print "----in----__init__----"

def __getitem__(self, item1):
print "-----in-----__getitem__-----", item1
if item1==5:
raise Exception('End')#For stop iteration (otherwise it will go to a loop)


t1 = Test1()

print "=============="

t1['saju'] #<----------IMP
t1.__getitem__('saju')

print "=============="
for x in t1:
pass

# OUTPUT
# ======
# ----in----__init__----
# ==============
# -----in-----__getitem__----- saju
# -----in-----__getitem__----- saju
# ==============
# -----in-----__getitem__----- 0
# -----in-----__getitem__----- 1
# -----in-----__getitem__----- 2
# -----in-----__getitem__----- 3
# -----in-----__getitem__----- 4
# -----in-----__getitem__----- 5
# Traceback (most recent call last):
# File "getitem.py", line 26, in
# for x in t1:
# File "getitem.py", line 15, in __getitem__
# raise Exception('End')#For stop iteration (otherwise it will go to a loop)
# Exception: End


#############################################3

class Test2:

def __init__(self):
print "----in----__init__----"

def __getitem__(self, item1, item2=0):
print "-----in-----__getitem__-----", item1, item2
if item1==5:
raise Exception('End')#For stop iteration (otherwise it will go to a loop)


t2 = Test2()

print "=============="

t2['saju'] #<----------IMP
t2.__getitem__('saju','1000')

print "=============="

for x in t2:
pass

# OUTPUT
# ======
# ----in----__init__----
# ==============
# -----in-----__getitem__----- saju 0
# -----in-----__getitem__----- saju 1000
# ==============
# -----in-----__getitem__----- 0 0
# -----in-----__getitem__----- 1 0
# -----in-----__getitem__----- 2 0
# -----in-----__getitem__----- 3 0
# -----in-----__getitem__----- 4 0
# -----in-----__getitem__----- 5 0
# Traceback (most recent call last):
# File "getitem.py", line 72, in
# for x in t2:
# File "getitem.py", line 60, in __getitem__
# raise Exception('End')#For stop iteration (otherwise it will go to a loop)
# Exception: End



#############################################

Thursday, January 6, 2011

Python calculate time taken to execute a function

Python calculate time taken to execute(run) a code or function or script.

>>> now = time.time()

>>> content1 = Myclass().content()  <---- do some works

>>> time.time() - now
22.43316888809204  <-------time taken to do that works

Sunday, January 2, 2011

python if in operation with string

python "if in" operation with string

>>> name = 'smithjohnannaivan'
>>>
>>> if 'john' in name:
...     print '---ok-----'
...
---ok-----
>>>