1、classMyWith(object):
2、exec(compile(__file__f.read(),__file__,"exec"))
3、property(fget=None,fset=None,fdel=None,=None)
4、executingfoo(
5、staticmethod装饰器
6、raiseException
7、神秘eval
8、A.class_foo("para")#更直接的类方法调用
9、defscore(self):
10、returnwrer
11、formatter=optparse.TitledHelpFormatter(width=78),
12、类中两种常用的装饰,首先区分一下他们
13、#常见with使用场景
14、returnfunc(*args)
15、def__init__(self):
16、x版本,你可以查看代码中的注释或文档字符串。通常,Python
17、return','.join(map(str,self.lst))
18、executingstatic_foo(para)
19、详细原理可以查看这篇文章,浅谈Python的with语句
20、#直接调用噗通的成员方法
21、printnum
22、raiseValueError('scoremustbetween0~100!')
23、defclass_foo(cls,x):
24、各种时间形式转换
25、action={#可以看做是一个sandbox
26、obj=TestIter()
27、------分割线-----
28、defprocess_command_line(argv):
29、"test_second":test_second,
30、return3
31、my_test=TestGetAttr()
32、#输出结果
33、print"runningafterException"
34、sys.exit(status)
35、ifargs:
36、通过yield和__iter__的结合,我们可以把一个对象变成可迭代的
37、fromfunctoolsimportpartial
38、x版本的语法或特性,那么在Python
39、print"__init__method"
40、defsum(a,b):
41、'export','info','interface','stream']
42、returna+b
43、defwrer(*extra_args):
44、defscore(self,value):
45、字符串格式化
46、#所有奇数都会返回True,偶数会返回False被过滤掉
47、print"ExitedwithoutException"
48、在stackoverflow给出了类似与partial的运行方式
49、return0#success
50、t2=Test()
51、res=eval(condition,action)#解释condition并根据action对应的动作执行
52、classTestIter(object):
53、装饰器之单例
54、printnew_lst
55、fromdecoratorimportinterface,export,stream
56、deftest_second(num):
57、thenameofoneoftheobject’sattributes,theresultisthevalueof
58、该list中填写可以import的类或者函数名,可以起到限制的import的作用,防止外部import其他函数或者类
59、exceptAttributeError:#没有该属性,且没有指定返回值的情况下
60、看一下下面这个例子
61、runningmy_with
62、Returna2-tuple:(settingsobject,argslist).
63、#checknumberofarguments,verifyvalues,etc.:
64、ExitedwithException
65、forlineinmy_file:
66、action={
67、defsay(self):
68、parser=optparse.OptionParser(
69、利用用闭包的特性绑定预先绑定一些函数参数,返回一个可调用的变量,直到真正的调用执行
70、exec"test_second"inaction
71、printobj
72、@singleton
73、deftest_eavl():
74、provided,otherwiseAttributeErrorisraised.
75、printfilter(lambdax:x%2!=0,lst)
76、runningbeforeException
77、'-h','--help',action='help',
78、print"__exit__method"
79、deftest_three_method():
80、instances[cls]=cls(*args,**kwargs)
81、证明了会先执行__enter__方法,然后调用with内的逻辑,最后执行__exit__做退出处理,并且,即使出现异常也能正常退出
82、partial使用上很像C++中仿函数(函数对象).
83、returnself#返回对象给as后的变量
84、raiseValueError('scoremustbeaninteger!')
85、defpartial(func,*part_args):
86、x版本中,使用注释的语法略有不同,可以使用“#”符号开头来注释单行代码,也可以使用三引号(""")来注释多行代码。
87、使用装饰器实现简单的单例模式
88、withopen('data.csv','wb')asf:
89、classStudent(object):
90、#单例装饰器
91、fromstorageimportStorage
92、普通成员函数,其中第一个隐式参数为对象
93、deftest_third():
94、def__exit__(self,exc_type,exc_value,exc_traceback):
95、deftest_second():
96、定义私有类属性
97、在传入字符串时,会使用compile(source,'
98、fget是获取属性的值的函数,fset是设置属性值的函数,fdel是删除属性的函数,是一个字符串(likeacomment).从实现来看,这些参数都是可选的
99、property有三个方法getter(),setter()和delete()来指定fget,fset和fdel。这表示以下这行
100、print"executingstatic_foo(%s)"%x
101、fromserverimportServer
102、test_partial()
103、def__iter__(self):
104、执行结果如下:
105、"para":5,
106、ifexc_tracebackisNone:
107、settings,args=parser.parse_args(argv)
108、`argv`isalistofarguments,or`None`for``sys.argv[1:]``.
109、getattr(object,name[,default])Returnthevalueof
110、obj=A()
111、printt1,t2
112、t1=Test()
113、obj.class_foo("para")#此处类作为隐式参数被传入,就是cls
114、property装饰器
115、print"runningmy_with"
116、#函数输出
117、@property#相当于property.getter(score)或者property(score)
118、"test_third":test_third
119、print"__enter__method"
120、classTest(object):
121、defsingleton(cls):
122、@classmethod#使用classmethod进行装饰
123、importcsv
124、相对filter而言,map和reduce使用的会更频繁一些,filter正如其名字,按照某种规则过滤掉一些元素
125、deffoo(self,x):
126、staticmethod装饰器,没有任何隐式参数.python中的静态方法类似与C++中的静态方法
127、deftest_getattr():
128、writer.writerows(data)#多行写入
129、ifvalue100:
130、def_singleton(*args,**kwargs):
131、Python奇技淫巧
132、deftest_first():
133、>>>name="andrew"
134、printline
135、reader=csv.reader(f)
136、读写csv文件
137、例如,Python
138、__exit__method
139、test_exec()#无法看到执行结果
140、returnsettings,args
141、filter的用法
142、yieldele
143、print"runningbeforeException"
144、通过__str__的重写,可以直接通过想要的形式打印对象
145、x版本的代码会包含注释或文档字符串,明确指出它适用于Python
146、withopen('data.csv','rb')asf:
147、frombaseimportAPIBase
148、forrowinreader:
149、[1,3,5]
150、returninstances[cls]
151、if__name__=='__main__':
152、foreleinxrange(len(self.lst)):
153、returnself.read()
154、exec和eval在执行代码时,除了返回值其他行为都相同
155、print"AttributeError!"
156、__repr__=__str__
157、File"test_with.py",line33,in
158、deftest_iter():
159、new_lst=lst[0]iflstisnotNoneelseNone
160、thenamedattributeofobject.namemustbeastring.Ifthestringis
161、'Storage','disable_logging_to_stderr','enable_logging_to_kids',
162、lst=[1,2,3]
163、Traceback(mostrecentcalllast):
164、enable_logging_to_kids,info)
165、status=main()
166、#单行注释,三对双引号多行注释
167、A.static_foo("para")
168、exec在Python中会忽略返回值,总是返回None,eval会返回执行代码或语句的返回值
169、pass
170、Exception
171、classA(object):
172、self._score=value
173、#python内建函数
174、defread(self):
175、exceptAttributeError:
176、executingclass_foo(
177、parser.error('programtakesnocommand-linearguments;'
178、"test_first":test_first,
179、printrow
180、with的魔力
181、#run(settings,args)
182、args.extend(extra_args)
183、test_iter()
184、Python
185、settings,args=process_command_line(argv)
186、#initializetheparserobject:
187、def__enter__(self):
188、File"bin/python",line34,in
189、test_first()
190、#-*-coding:utf-8-*-
191、ExitedwithoutException
192、通过string类型的name,返回对象的name属性(方法)对应的值,如果属性不存在,则返回默认值,相当于object.name
193、print"------分割线-----"
194、要快速判断一个Python代码是否为Python
195、printres
196、只发一张网上的,然后差文档就好了,这个是记不住的
197、#向csv文件写入
198、fun=partial(sum,2)#事先绑定一个参数,fun成为一个只需要一个参数的可调用变量
199、print"third"
200、deftest_exec():
201、#执行结果
202、print"testmethod"
203、print"MethodError!"
204、#从csv中读取文件,基本和传统文件读取类似
205、getattr(my_test,"say")()
206、#普通成员函数
207、'"%s"ignored.'%(args,))
208、fromutilimport(LogFormatter,disable_logging_to_stderr,
209、#!/usr/bin/envpython
210、help='Showthishelpmessageandexit.')
211、defstatic_foo(x):
212、testattribute
213、x.foobar.Ifthenamedattributedoesnotexist,defaultisreturnedif
214、classTestGetAttr(object):
215、obj.static_foo("para")#静态方法并没有任何隐式参数,但是要通过对象或者类进行调用
216、"test_second":test_second
217、x版本还引入了一些新的语法和特性,例如print()函数、增强的异常处理、新的内置函数等。
218、test="testattribute"
219、def__str__(self):
220、with语句需要支持上下文管理协议的对象,上下文管理协议包含__enter__和__exit__两个方法.with语句建立运行时上下文需要通过这两个方法执行进入和退出操作.
221、ifclsnotininstances:#如果不存在,则创建并放入字典
222、test_three_method()
223、File"test_with.py",line28,intest_with
224、writer=csv.writer(f)
225、('xiaoming','china','10'),
226、fromclientimportClient
227、withMyWith()asmy_with:
228、命令行处理
229、#打印结果
230、__all__=['APIBase','Client','LogFormatter','Server',
231、parser.add_option(#customizeddescription;put--helplast
232、condition="para==5andtest_second(test_first)>5"
233、test_getattr()
234、argv=sys.argv[1:]
235、return_singleton
236、getattr
237、returnFalse
238、#使用范例
239、print"second"
240、defmain(argv=None):
241、deftest_with():
242、@score.setter#相当于score=property.setter(score)
243、if__name__=='_
244、classmethod装饰器,类方法(给人感觉非常类似于OC中的类方法),其中第一个隐式参数为类
245、try:
246、thatattribute.Forexample,getattr(x,‘foobar’)isequivalentto
247、__init__method
248、iter魔法
249、print"executingclass_foo(%s,%s)"%(cls,x)
250、else:
251、知道具体原理,我们可以自定义支持上下文管理协议的类,类中实现__enter__和__exit__方法
252、'mynameisandrew'
253、withopen("test.","r")asmy_file:#注意,是__enter__()方法的返回值赋值给了my_file,
254、#licationcodehere,like:
255、testmethod
256、self.lst=[1,2,3,4,5]
257、eval我理解为一种内嵌的python解释器(这种解释可能会有偏差),会解释字符串为对应的代码并执行,并且将执行结果返回
258、args=list(part_args)
259、print"executingfoo(%s,%s)"%(self,x)
260、test_with()
261、returnTrue
262、#furtherprocesssettings&argsifnecessary
263、ifargvisNone:
264、deftest_partial():
265、print"hello"
266、#两者具有相同的地址
267、将property与装饰器结合实现属性私有化(更简单安全的实现get和set方法)
268、writer.writerow(['name','address','age'])#单行写入
269、('Lily','USA','12')]
270、x版本。
271、当条件满足时,返回的为等号后面的变量,否则返回else后语句
272、obj.foo("para")#此处obj对象作为成员函数的隐式参数,就是self
273、一行作判断
274、instances=dict()#初始为空
275、一个非常好用,很多人又不知道的功能
276、x版本中运行时将会出现错误。
277、>>>"mynameis{name}".format(name=name)
278、print"ExitedwithException"
279、ifnotisinstance(value,int):
280、returnself._score
281、printgetattr(my_test,"test")
282、神奇partial
283、data=[
284、如果你无法找到注释或文档字符串,可以尝试运行代码并查看错误消息。如果代码中使用了Python
285、其中上下文表达式是跟在with之后的表达式,该表示大返回一个上下文管理对象
286、当发布python第三方package时,并不希望代码中所有的函数或者class可以被外部import,在__init__.py中添加__all__属性,
287、fornuminobj:
288、@staticmethod#使用staticmethod进行装饰
289、add_help_option=None)
290、printfun(3)#实现执行的即是sum(2,3)
291、exec
292、lst=[1,2,3,4,5,6]
293、#defineoptionshere:
294、returnnum
295、__enter__method
296、最后,如果你无法确定代码的版本,可以使用Python的version()函数来获取当前Python解释器的版本。