""" 面向对象编程 类 继承:多继承 类中所有开头的_方法都是内置的来自于父类的方法 对象 创建对象和调用 方法 类方法 对象方法 构造方法 静态方法 """ import types def jpfn(n): print('金品肥牛 100元一份') if type(n)==types.FunctionType: return n()+100 return n+100 def sc(n): print('蔬菜双拼 10元一份') if type(n)==types.FunctionType: return n()+10 return n+10 @jpfn @sc def mala(): print('麻辣锅底: 10元一份') return 10 print('消费:'+str(mala)) #----------------------------------------------------------- class perso(): # name=None # __myname=None def __init__(self,name=None): self.name=name def show(self,s): print(self.name,s) p=perso("邓超") # p.name("邓超") p.show("登场")
函数调用
定义一个函数:给了函数一个名称,指定了函数里包含的参数,和代码块结构。
这个函数的基本结构完成以后,你可以通过另一个函数调用执行,也可以直接从 Python 命令提示符执行。
定义函数def printme( str ): "打印任何传入的字符串"
print (str);
return;
调用函数
printme("我要调用用户自定义函数!");
printme("再次调用同一函数");
参数传递
在 python 中,类型属于对象,变量是没有类型的:
a=[1,2,3] a="Runoob"以上代码中,[1,2,3]
是 List 类型,"Runoob" 是 String 类型,
而变量 a 是没有类型,
她仅仅是一个对象的引用(一个指针),
可以是 List 类型对象,也可以指向 String 类型对象。
可更改(mutable)与不可更改(immutable)对象
在 python 中,strings, tuples,
和 numbers 是不可更改的对象,
而 list,dict 等则是可以修改的对象。
不可变类型:变量赋值 a=5 后再赋值 a=10,这里实际是新生成一个 int 值对象 10,再让 a 指向它,而 5 被丢弃,不是改变a的值,相当于新生成了a。
可变类型:变量赋值 la=[1,2,3,4] 后再赋值 la[2]=5 则是将 list la 的第三个元素值更改,本身la没有动,只是其内部的一部分值被修改了。
python 函数的参数传递:
不可变类型:类似 c++ 的值传递,如 整数、字符串、元组。如fun(a),传递的只是a的值,没有影响a对象本身。
比如在 fun(a)内部修改 a 的值,只是修改另一个复制的对象,不会影响 a 本身。
可变类型:类似 c++ 的引用传递,如 列表,字典。如 fun(la),则是将 la 真正的传过去,
修改后fun外部的la也会受影响
python 中一切都是对象,严格意义我们不能说值传递还是引用传递,我们应该说传不可变对象和传可变对象。
函数:独立定义,独立调用 def foo(): pass foo() 方法:依赖定义,依赖调用 A def foo() pass A().foo()学习函数 语法 def 函数名称(参数): #函数体 参数:普通 关键参数 动态参数1. 变量作用域 全局 本地 闭包 局部什么情况下产生新的作用域 def class 2. 函数作为参数:回调 3. 函数返回值可以有多个 ------------------------------------------ 函数 装饰 @class method object''' # def foo(n,m): # print("第一个参数是{0},第二个参数是{1}".format(n,m)) # foo(5,4) # # def foo2(n=0,m=0): # print("第一个参数是{0},第二个参数是{1}".format(n,m)) # foo2(m=5,n=4) # foo2() # def foo3(*args): # sum=0 # for n in args: # sum = sum + n # return sum # rs=foo3(1) # print(rs) # rs=foo3(1,2,3,4) # print(rs) # # abc="g" #Global # #nonlocal # def testscope(): # a="aaa" # def ts(): # nonlocal a # a="bbb" # print(a) # print(a) # ts() # print(a) # # ts() # testscope() # def ts(): # a="aa" # if True : # b ="bb" # print(a) # print(b) # ts()# def selectone(data,r): # for a in data : # if r(a) : # return a # # def guizi(d): # return d % 3 == 0 # def xinguizi(d): # return d % 7 == 0 # print(selectone([1,2,4,5,6,7,8.9],xinguizi)) # def daxiao(n,n1): # if n > n1 : # n,n1=n1,n # return n,n1 # a,b=daxiao(7,3) # print(a,b)