三元运算

三元运算(三目运算),是对简单的条件语句的缩写

  1. # 书写格式
  2.  
  3. result = 1 if 条件 else 2
  4.  
  5. # 如果条件成立,那么将 “值1” 赋值给result变量,否则,将“值2”赋值给result变量

基本数据类型补充

set

set集合,是一个无序且不重复的元素集合,它的主要作用如下:

  • 去重,把一个列表变成集合,就自动去重了

  • 关系测试,测试两组数据之前的交集、差集、并集等关系

集合对象是一组无序排列的可哈希的值:集合成员可以做字典的键

集合分类:可变集合、不可变集合

可变集合(set):可添加和删除元素,非可哈希的,不能用作字典的键,也不能做其他集合的元素

不可变集合(frozenset):与上面恰恰相反

  1. class set(object):
  2. """
  3. set() -> new empty set object
  4. set(iterable) -> new set object
  5.  
  6. Build an unordered collection of unique elements.
  7. """
  8. def add(self, *args, **kwargs): # real signature unknown
  9. """
  10. Add an element to a set,添加元素
  11. This has no effect if the element is already present.
  12. """
  13. pass
  14.  
  15. def clear(self, *args, **kwargs): # real signature unknown
  16. """ Remove all elements from this set. 清除内容"""
  17. pass
  18.  
  19. def copy(self, *args, **kwargs): # real signature unknown
  20. """ Return a shallow copy of a set. 浅拷贝 """
  21. pass
  22.  
  23. def difference(self, *args, **kwargs): # real signature unknown
  24. """
  25. Return the difference of two or more sets as a new set. A中存在,B中不存在 ( in A not in B )
  26. (i.e. all elements that are in this set but not the others.)
  27. """
  28. pass
  29.  
  30. def difference_update(self, *args, **kwargs): # real signature unknown
  31. """ Remove all elements of another set from this set. 从当前集合中删除和B中相同的元素"""
  32. pass
  33.  
  34. def discard(self, *args, **kwargs): # real signature unknown
  35. """
  36. Remove an element from a set if it is a member.
  37.  
  38. If the element is not a member, do nothing. 移除指定元素,不存在不保错
  39. """
  40. pass
  41.  
  42. def intersection(self, *args, **kwargs): # real signature unknown
  43. """
  44. Return the intersection of two sets as a new set. 交集
  45.  
  46. (i.e. all elements that are in both sets.)
  47. """
  48. pass
  49.  
  50. def intersection_update(self, *args, **kwargs): # real signature unknown
  51. """ Update a set with the intersection of itself and another. 取交集并更更新到A中 """
  52. pass
  53.  
  54. def isdisjoint(self, *args, **kwargs): # real signature unknown
  55. """ Return True if two sets have a null intersection. 如果没有交集,返回True,否则返回False"""
  56. pass
  57.  
  58. def issubset(self, *args, **kwargs): # real signature unknown
  59. """ Report whether another set contains this set. 是否是子序列"""
  60. pass
  61.  
  62. def issuperset(self, *args, **kwargs): # real signature unknown
  63. """ Report whether this set contains another set. 是否是父序列"""
  64. pass
  65.  
  66. def pop(self, *args, **kwargs): # real signature unknown
  67. """
  68. Remove and return an arbitrary set element.
  69. Raises KeyError if the set is empty. 移除元素
  70. """
  71. pass
  72.  
  73. def remove(self, *args, **kwargs): # real signature unknown
  74. """
  75. Remove an element from a set; it must be a member.
  76.  
  77. If the element is not a member, raise a KeyError. 移除指定元素,不存在保错
  78. """
  79. pass
  80.  
  81. def symmetric_difference(self, *args, **kwargs): # real signature unknown
  82. """
  83. Return the symmetric difference of two sets as a new set. 对称差集 (not in a and b )
  84.  
  85. (i.e. all elements that are in exactly one of the sets.)
  86. """
  87. pass
  88.  
  89. def symmetric_difference_update(self, *args, **kwargs): # real signature unknown
  90. """ Update a set with the symmetric difference of itself and another. 对称差集,并更新到a中 """
  91. pass
  92.  
  93. def union(self, *args, **kwargs): # real signature unknown
  94. """
  95. Return the union of sets as a new set. 并集
  96. (i.e. all elements that are in either set.)
  97. """
  98. pass
  99.  
  100. def update(self, *args, **kwargs): # real signature unknown
  101. """ Update a set with the union of itself and others. 更新 """
  102. pass

set

练习:寻找差异

  1. old_dict = {
  2. "#1":11,
  3. "#2":22,
  4. "#3":100,
  5. }
  6.  
  7. new_dict = {
  8. "#1":33,
  9. "#4":22,
  10. "#7":100,
  11. }
  12.  
  13. old_set = set(old_dict.keys())
  14. new_set = set(new_dict.keys())
  15.  
  16. same_set = old_set.intersection(new_set)
  17. up_set = new_set.difference(old_set)
  18.  
  19. ret_dict = {}
  20. for k in same_set:
  21. ret_dict[k]=new_dict[k]
  22.  
  23. for i in up_set:
  24. ret_dict[i]=new_dict[i]
  25.  
  26. print(ret_dict)
  27. # print(old_set)
  28. # print(new_set)

深浅拷贝

一、数字和字符串

对于 数字 和 字符串 而言,赋值、浅拷贝和深拷贝无意义,因为其永远指向同一个内存地址。

  1. import copy
  2.  
  3. a = 132
  4. b = 'Ales'
  5.  
  6. # ## 浅拷贝 ##
  7. aa = copy.copy(a)
  8. bb = copy.copy(b)
  9.  
  10. # ## 深拷贝 ##
  11. aaa = copy.deepcopy(a)
  12. bbb = copy.deepcopy(b)
  13.  
  14. print(id(a),id(aa),id(aaa))
  15. print(id(b),id(bb),id(bbb))
  16.  
  17. # ## 1691783456 1691783456 1691783456
  18. # ## 47227376 47227376 47227376

二、其他基本数据类型

对于字典、元祖、列表 而言,进行赋值、浅拷贝和深拷贝时,其内存地址的变化是不同的。

1、赋值

赋值,只是创建一个变量,该变量指向原来内存地址,如:

  1. n1 = {"k1": "wu", "k2": 123, "k3": ["alex", 456]}
  2.  
  3. n2 = n1

2、浅拷贝

浅拷贝,在内存中只额外创建第一层数据

  1. import copy
  2.  
  3. n1 = {"k1": "wu", "k2": 123, "k3": ["alex", 456]}
  4.  
  5. n3 = copy.copy(n1)
  6.  
  7. print(id(n1),id(n3))
  8. print(id(n1["k1"]),id(n3["k1"]))
  9.  
  10. # 44947080 45383304
  11. # 45327056 45327056

3、深拷贝

深拷贝,在内存中将所有的数据重新创建一份(排除最后一层,即:python内部对字符串和数字的优化)

  1. import copy
  2.  
  3. n1 = {"k1": "wu", "k2": 123, "k3": ["alex", 456]}
  4.  
  5. n4 = copy.deepcopy(n1)
  6.  
  7. print(id(n1),id(n4))
  8. print(id(n1["k3"]),id(n4["k3"]))
  9. print(id(n1["k3"][0]),id(n4["k3"][0]))
  10.  
  11. # 56088200 56460680
  12. # 58962760 58930696
  13. # 56506216 56506216

函数

一、背景

在学习函数之前,一直遵循:面向过程编程,

即:根据业务逻辑从上到下实现功能,其往往用一长段代码来实现指定功能,开发过程中最常见的操作就是粘贴复制,也就是将之前实现的代码块复制到现需功能处,如下:

  1. while True
  2. if cpu利用率 > 90%:
  3. #发送邮件提醒
  4. 连接邮箱服务器
  5. 发送邮件
  6. 关闭连接
  7.  
  8. if 硬盘使用空间 > 90%:
  9. #发送邮件提醒
  10. 连接邮箱服务器
  11. 发送邮件
  12. 关闭连接
  13.  
  14. if 内存占用 > 80%:
  15. #发送邮件提醒
  16. 连接邮箱服务器
  17. 发送邮件
  18. 关闭连接

腚眼一看上述代码,if条件语句下的内容可以被提取出来公用,如下:

  1. def 发送邮件(内容)
  2. #发送邮件提醒
  3. 连接邮箱服务器
  4. 发送邮件
  5. 关闭连接
  6.  
  7. while True
  8.  
  9. if cpu利用率 > 90%:
  10. 发送邮件('CPU报警')
  11.  
  12. if 硬盘使用空间 > 90%:
  13. 发送邮件('硬盘报警')
  14.  
  15. if 内存占用 > 80%:

对于上述的两种实现方式,第二次必然比第一次的重用性和可读性要好,其实这就是函数式编程和面向过程编程的区别:

  • 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可

  • 面向对象:对函数进行分类和封装,让开发“更快更好更强...”

简单的例子:求一个长方形的周长和面积。

面向过程的程序设计方式:

1、确定长方形周长和面积的算法。

2、编写两个方法(函数)分别计算长方形的周长和面积。

3、求周长的方法(函数)和求面积的方法(函数)需要两个参数,分别是长方形的长和宽。

面向对象的程序设计方式:

1、一个长方形可以看成一个长方形对象。

2、一个长方形对象有两个状态(长和宽)和两个行为(求周长和求面积)。

3、将所有长方形的共性抽取出来,设计一个长方形类。

4、通过长方形对象的行为,就可以求出某个具体的长方形对象的周长和面积。

二、函数定义和使用

  1. def 函数名(参数):
  2.  
  3. ...
  4. 函数体
  5. ...
  6. 返回值

函数的定义主要有如下要点:

  • def:表示函数的关键字
  • 函数名:函数的名称,日后根据函数名调用函数
  • 函数体:函数中进行一系列的逻辑计算,如:发送邮件、计算出 [11,22,38,888,2]中的最大数等...
  • 参数:为函数体提供数据
  • 返回值:当函数执行完毕后,可以给调用者返回数据。

1、返回值

函数是一个功能块,该功能到底执行成功与否,需要通过返回值来告知调用者。

返回多个对象时,封装成一个元组返回!

以上要点中,比较重要有参数和返回值:

  1. def 发送短信():
  2. 发送短信的代码...
  3. if 发送成功:
  4. return True
  5. else:
  6. return False
  7.  
  8. while True:
  9. # 每次执行发送短信函数,都会将返回值自动赋值给result
  10. # 之后,可以根据result来写日志,或重发等操作
  11. result = 发送短信()
  12. if result == False:
  13. 记录日志,短信发送失败...

2、参数

函数有三种不同的参数:

  • 普通参数
  • 默认参数
  • 动态参数
  1. # ######### 定义函数 #########
  2.  
  3. # name 叫做函数func的形式参数,简称:形参
  4. def func(name):
  5. print name
  6.  
  7. # ######### 执行函数 #########
  8. # 'alex' 叫做函数func的实际参数,简称:实参
  9. func('alex')

普通参数

  1. def func(name, age = 18):
  2.  
  3. print "%s:%s" %(name,age)
  4.  
  5. # 指定参数
  6. func('wupeiqi', 19)
  7. # 使用默认参数
  8. func('alex')
  9.  
  10. 注:默认参数需要放在参数列表最后

默认参数

  1. def func(*args):
  2. print(args,type(args))
  3.  
  4. # 执行方式一
  5. func(11,33,4,4454,5,['',''])
  6.  
  7. # (11, 33, 4, 4454, 5, ['11', '22']) <class 'tuple'>
  8.  
  9. # 执行方式二
  10. li = [11,2,2,3,3,4,54]
  11.  
  12. func(li)
  13. # ([11, 2, 2, 3, 3, 4, 54],) <class 'tuple'> 注意此处!元组第一个元素为列表
  14.  
  15. func(*li)
  16. # (11, 2, 2, 3, 3, 4, 54) <class 'tuple'>

动态参数一

  1. def func(**kwargs):
  2. print(kwargs)
  3.  
  4. # 执行方式一
  5. func(name='wupeiqi',age=18)
  6.  
  7. # 执行方式二
  8. li = {'name':'wupeiqi', 'age':18, 'gender':'male'}
  9. func(**li)
  10.  
  11. # {'name': 'wupeiqi', 'age': 18}
  12. # {'name': 'wupeiqi', 'age': 18, 'gender': 'male'}

动态参数二

  1. def f1(*a,**aa):
  2. print(a,type(a))
  3. print(aa,type(aa))
  4.  
  5. f1(11,22,33,k1=123,k2=456)
  6.  
  7. # (11, 22, 33) <class 'tuple'>
  8. # {'k1': 123, 'k2': 456} <class 'dict'>

动态参数一,二结合

3.函数名可以做参数传递

  函数名()  =>  执行函数

  函数名    =>  代指函数内容

  1. def f1():
  2. print("F1")
  3. return "F1"
  4.  
  5. def f2(arg):
  6. arg()
  7. print("F2")
  8. return "F2"
  9.  
  10. f2(f1)
  11.  
  12. # F1
  13. # F2

函数式编程、面向过程编程、面向对象编程

函数式编程 :主要思想是把运算过程尽量写成一系列嵌套的函数调用。增强代码的重用性和可读性

传统的编程模式:

  var a = 1 + 2;

  var b = a * 3;

  var c = b - 4;

函数式编程要求使用函数,我们可以把运算过程定义为不同的函数,然后写成下面这样:

  var result = subtract(multiply(add(1,2), 3), 4);

函数式编程具有五个鲜明的特点

  (1)函数是"第一等公民",与其他数据类型一样,处于平等地位,可以赋值给其他变量,也可以作为参数,传入另一个函数,或者作为别的函数的返回值。

  (2)申明式(Declarative)的编程方式,相对于命令式而言,命令式程序设计大量使用可变对象和指令。习惯于创建对象或者变量,并且修改它们的状态或者值,或者喜欢提供一系列指令,要求程序执行。

  对于申明式编程范式,不需要提供明确的指令操作,所有的细节指令将会更好的被程序库所封装,只需要提出要求,申明用意即可。

  (3)无"副作用"(side effect),指的是函数内部与外部互动(最典型的情况,就是修改全局变量的值),产生运算以外的其他结果。

  显式函数指函数与外界交换数据的唯一渠道就是参数和返回值,显式函数不会去读取或者修改函数的外部状态,

  隐式函数除了参数和返回值外,还会读取外部信息,或者可能修改外部信息。

  (4)不修改状态,函数式编程只是返回新的值,不修改系统变量。因此,不修改变量,也是它的一个重要特点。

  在其他类型的语言中,变量往往用来保存"状态"(state)。不修改变量,意味着状态不能保存在变量中。函数式编程使用参数保存状态,最好的例子就是递归。

  (5)尾递归优化,尾递归操作处于函数的最后一步。这种情况下,函数的工作其实已经完成(剩余工作就是再次调用它自身)。

  编译器可以进行优化,用新函数的帧栈覆盖掉老函数的帧栈,避免递归操作不断申请栈空间。

函数式编程好处

  (1)代码简洁,开发快速。函数式编程大量使用函数,减少了代码的重复,因此程序比较短,开发速度较快。

  (2)接近自然语言,易于理解。

  (3)易于并发编程(concurrency)。函数式编程不需要考虑"死锁"(deadlock),因为它不修改变量,所以根本不存在"锁"线程的问题。不必担心一个线程的数据,被另一个线程修改,所以可以很放心地把工作分摊到多个线程,部署"并发编程"。

面向过程是一种以事件为中心的编程思想,以功能(行为)为导向,面向过程类型的编码是需求的直译过程。按模块化的设计,就是分析出解决问题所需要的步骤,然后用函数把这些步骤一步一步实现,实现的时候一个一个依次调用。

面向对象是一种以事物为中心的编程思想,以数据(属性)为导向,将具有相同一个或者多个属性的物体抽象为“类”,将他们包装起来;而有了这些数据(属性)之后,我们再考虑他们的行为(对这些属性进行怎样的操作),是把构成问题的事物分解成各个对象,建立对象的目的不是为了完成一个步骤,而是为了描述某个事物在整个解决问题的步骤中的行为。

内置函数

注:查看详细猛击这里

open()函数 =>  详情点击

lambda表达式

学习条件运算时,对于简单的 if else 语句,可以使用三元运算来表示,即:

  1. # 普通条件语句
  2. if 1 == 1:
  3. name = 'eric'
  4. else:
  5. name = 'alex'
  6.  
  7. # 三元运算
  8. name = 'eric' if 1 == 1 else 'alex'

对于简单的函数,也存在一种简便的表示方式,即:lambda表达式

  1. func = lambda x,y : x+1
  • 参数  x,y
  • 函数体
  • 隐含 return
  • func 函数名
  1. # ###################### 普通函数 ######################
  2. def f1(x):
  3. return x+100
  4.  
  5. result = f1(10)
  6. print(result)
  7.  
  8. # ###################### lambda ######################
  9.  
  10. my_lambda = lambda x : x+100
  11. result = my_lambda(10)
  12. print(result)

注意 :

  1. def makelist():
  2. L = []
  3. for i in range(5):
  4. L.append(lambda x: i**x)
  5. return L
  6.  
  7. mylist = makelist()
  8.  
  9. >>> mylist[0](0)
  10. 1
  11. >>> mylist[0](1)
  12. 4
  13. >>> mylist[0](2)
  14. 16

i 为enclosing variables,直到lambda函数调用时,i 的最终值为4

具体参考python作用域

for 循环中的 lambda 表达式

第一种:

f = [ lambda x: x*i  for i in range(4) ]

调用结果为:

  1. >>> f = [lambda x:x*i for i in range(4)]
  2. >>> f[0](1)
  3. 3 # 1*3
  4. >>> f[1](1)
  5. 3 # 1*3
  6. >>> f[2](1)
  7. 3 # 1*3
  8. >>> f[0](3)
  9. 9 # 3*3
  10. >>> f[1](3)
  11. 9 # 3*3
  12. >>> f[2](3)
  13. 9 # 3*3

表达式展开为函数代码:

  1. def func():
  2. fs = []
  3. for i in range(4):
  4. def lam(x):
  5. return x*i
  6. fs.append(lam)
  7. return fs
  8.  
  9. >>> f = func()
  10. >>> f[0](3)
  11. 9
  12. >>> f[2](3)
  13. 9
  14. >>> f[1](3)
  15. 9

  当调用func()时,每次循环都将lam()函数的地址放入到fs列表中。

  循环中的lam()函数,都未绑定i的值,直到循环结束,i的值为3,并将lam()函数中所用到的 i 值定为3。

  到调用时,i 的值 一直保持为3。

另一种:

f = [ lambda :i*i for i in range(4) ]  (没有传入x值)

  1. >>> f = [lambda :i*i for i in range(4)]
  2. >>> f[0]()
  3. 9
  4. >>> f[1]()
  5. 9
  6. >>> f[2]()
  7. 9
  8. >>> f[3]()
  9. 9

第二种:

f = [ lambda i=i: i*i for i in range(4) ]

表达式调用结果为:

  1. >>> f1 = [lambda i=i: i*i for i in range(4)]
  2. >>> f1[0]()
  3. 0
  4. >>> f1[1]()
  5. 1
  6. >>> f1[2]()
  7. 4
  8. >>> f1[3]()
  9. 9

展开为函数为:

  1. def func():
  2. fs = []
  3. for i in range(4)
  4. def lam(x=i): # 即 i=i
  5. return x*x # 即 i*i
  6. fs.append(lam)
  7. return fs

  当调用func()函数时,每次循环都将lam()函数的地址放入到fs列表中。

  但是在每次循环中,都将 i 的值绑定到了 x 上,所以直到循环结束,每次的 x 的值都不一样。

  到调用时,x 的值为当时绑定的值。

  当有给 lam()函数 进行参数传递时,参数就绑定到 x 的值上。

  1. >>> f1 = [lambda i=i: i*i for i in range(4)]
  2. >>> f1[0](8)
  3. 64
  4. >>> f1[1](8)
  5. 64
  6. >>> f1[2](8)
  7. 64
  8. >>> f1[3](8)
  9. 64

第三种:

f = [ lambda x=i:i*i for i in range(4) ]

表达式调用结果为:

  1. >>> f2 = [lambda x=i: i*i for i in range(4)]
  2. >>> f2[0]()
  3. 9
  4. >>> f2[1]()
  5. 9
  6. >>> f2[2]()
  7. 9
  8. >>> f2[0](1)
  9. 9
  10. >>> f2[1](2)
  11. 9

传不传参数都不影响结果。展开后:

  1. def func():
  2. fs = []
  3. for i in range(4)
  4. def lam(x=i):
  5. return i*i
  6. fs.append(lam)
  7. return fs

  虽然 lam()函数 将 i 的值绑定到 x上,但是函数体中并没有使用到 x 的值,

  直到循环结束,i 的值变为3,才会在调用时使用。

递归

利用函数编写如下数列:

斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368...

斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1,F(2)=1, F(n)=F(n-1)+F(n-2)(n>=2,n∈N*)

  1. def f1(a1,a2):
  2. if a1 == 0:
  3. print(a1,a2)
  4. a3 = a1 + a2
  5. print(a3)
  6. f1(a2,a3)
  7.  
  8. f1(0,1)

第一种(递归法):

  写法最简洁,但是效率最低,会出现大量的重复计算,时间复杂度O(1.618^n),而且最深度1000

  1. def fi(n):
  2. if n <= 1:
  3. return n
  4. return fi(n-2) + fi(n-1)
  5.  
  6. for i in range(6):
  7. print(fi(i),end=' ')

第二种(递推法):

  递推法,就是递增法,时间复杂度是 O(n),呈线性增长,如果数据量巨大,速度会越拖越慢

  1. def fi(n):
  2. if n <= 1:
  3. return n
  4. a, b = 0, 1
  5. for i in range(n-1):
  6. a, b = b, a + b
  7.  
  8. return b

第三种(生成器):

  1. def fi(n):
  2. a, b = 0, 1
  3. while n >= 1 :
  4. a, b = b, a+b
  5. yield a
  6. n -= 1
  7.  
  8. for i in fi(6):
  9. print(i, end=' ')

第四种(类):

  1. class Fabinacci(object):
  2. def __init__(self, count):
  3. self.current = 0
  4. self.a = 0
  5. self.b = 1
  6. self.max = count
  7.  
  8. def __next__(self):
  9. if self.current < self.max:
  10. self.a,self.b = self.b, self.a + self.b
  11. self.current += 1
  12. return self.a
  13. else:
  14. raise StopIteration
  15.  
  16. def __iter__(self):
  17. return self
  18.  
  19. for i in Fabinacci(6):
  20. print(i, end=' ')

第五种(矩阵):

  因为幂运算可以使用二分加速,所以矩阵法的时间复杂度为 O(log n)

  用科学计算包numpy来实现矩阵法 O(log n)

  1. ### 1
  2. import numpy
  3. def fib_matrix(n):
  4. res = pow((numpy.matrix([[1, 1], [1, 0]])), n) * numpy.matrix([[1], [0]])
  5. return res[0][0]
  6. for i in range(10):
  7. print(int(fib_matrix(i)), end=' ')
  8.  
  9. ### 2
  10. # 使用矩阵计算斐波那契数列
  11. def Fibonacci_Matrix_tool(n):
  12. Matrix = npmpy.matrix("1 1;1 0")
  13. # 返回是matrix类型
  14. return pow(Matrix, n) # pow函数速度快于 使用双星好 **
  15.  
  16. def Fibonacci_Matrix(n):
  17. result_list = []
  18. for i in range(0, n):
  19. result_list.append(numpy.array(Fibonacci_Matrix_tool(i))[0][0])
  20. return result_list
  21. # 调用
  22. Fibonacci_Matrix(10)

练习题

1、简述普通参数、指定参数、默认参数、动态参数的区别

  1. # 普通参数:按照形式参数的指定位置 传入参数。
  2. # 指定参数:可以在实际参数里指定任意位置,传入参数。
  3. # 默认参数:如果实际参数没有给形式参数传入值  那么默认使用的参数就是默认参数 默认参数需要放到尾部
  4. # 动态参数:可以无限传入任意参数,如果是*代表传入参数的形式将会是元组 **表示将会是字典

2、写函数,计算传入字符串中【数字】、【字母】、【空格] 以及 【其他】的个数

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. def counts(str):
  5. num_counts=0
  6. al_counts=0
  7. space_num=0
  8. other=0
  9. for i in str:
  10. if i.isdigit():
  11. num_counts += 1
  12. elif i.isalpha():
  13. al_counts += 1
  14. elif i.isspace():
  15. space_num +=1
  16. else:
  17. other += 1
  18. print(num_counts,al_counts,space_num,other)
  19.  
  20. counts('123 456abc def g_*-/')

3、写函数,判断用户传入的对象(字符串、列表、元组)长度是否大于5。

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. def length(input):
  5. if isinstance(input,str) or isinstance(input,list) or isinstance(input,tuple):
  6. if len(input) > 5:
  7. print("大于5")
  8. return True
  9. else:
  10. print("小于5")
  11. return False
  12. else:
  13. print("类型错误!")
  14. return None
  15.  
  16. length("abc544")
  17.  
  18. li = ['','','','asd',45,22,]
  19. length(li)
  20.  
  21. tu=(11,22,33,44,)
  22. length(tu)
  23.  
  24. a =123
  25. length(a)

4、写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容。

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. def has_space(str):
  5. ret = False
  6. for i in str:
  7. if i.isspace():
  8. ret = True
  9. break
  10. return ret
  11.  
  12. ret = has_space('22 123')
  13. print(ret)

5、写函数,检查传入列表的长度,如果大于2,那么仅保留前两个长度的内容,并将新内容返回给调用者。

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. def check(li):
  5. if len(li)>2:
  6. del li[2:]
  7.  
  8. li = [11,22,33,44,55]
  9. check(li)
  10. print(li)

6、写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素,并将其作为新列表返回给调用者。

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. def check(li):
  5. return li[0:len(li):2]
  6.  
  7. li = [11,22,33,44,55,66,77,88,99]
  8. ll = check(li)
  9. print(ll)

7、写函数,检查传入字典的每一个value的长度,如果大于2,那么仅保留前两个长度的内容,并将新内容返回给调用者。

  1. dic = {"k1": "v1v1", "k2": [11,22,33,44]}
  2.  
  3. PS:字典中的value只能是字符串或列表
  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. dic = {"k1": "v1v1", "k2": [11,22,33,44],"k3":''}
  5.  
  6. def check(dic):
  7. for k,v in dic.items():
  8. if len(v)>2:
  9. dic[k]=v[0:2]
  10. return dic
  11.  
  12. check(dic)
  13. print(dic)

8、写函数,利用递归获取斐波那契数列中的第 10 个数,并将该值返回给调用者。

  1. #!/usr/bin/env python
  2. # -*-coding:utf-8 -*-
  3.  
  4. def f1(a1,a2,depth):
  5. if depth == 10:
  6. return a1
  7. a3 = a1 + a2
  8. a1 = f1(a2,a3,depth+1)
  9. return a1
  10.  
  11. a = f1(0,1,1)
  12. print(a)

【Python之路】第四篇--Python基础之函数的更多相关文章

  1. python之路第四篇(基础篇)

    一.冒泡算法实现: 方法一: li = [13,33,12,80,66,1] print li for m in range(4): num1 = li[m] num2 = li[m+1] if nu ...

  2. 【Python之路】第九篇--Python基础之线程、进程和协程

    进程与线程之间的关系 线程是属于进程的,线程运行在进程空间内,同一进程所产生的线程共享同一内存空间,当进程退出时该进程所产生的线程都会被强制退出并清除.线程可与属于同一进程的其它线程共享进程所拥有的全 ...

  3. Python之路第四天,基础(4)-装饰器,迭代器,生成器

    装饰器 装饰器(decorator)是一种高级Python语法.装饰器可以对一个函数.方法或者类进行加工.在Python中,我们有多种方法对函数和类进行加工,比如在Python闭包中,我们见到函数对象 ...

  4. 【Python之路】第一篇--Linux基础命令

    pwd 命令 查看”当前工作目录“的完整路径 pwd -P # 显示出实际路径,而非使用连接(link)路径:pwd显示的是连接路径 .   表示当前目录 ..  表示上级目录 /  表示根目录 ls ...

  5. Python之路(第四篇):Python基本数据类型列表、元组、字典

    一.列表 1.列表 list ,是一个类,li = [1,2,"nicholas"] li是通过list类创建的对象. 2.list特点: 用中括号括起来,用逗号分割每个元素,列表 ...

  6. Python之路(第八篇)Python内置函数、zip()、max()、min()

    一.python内置函数 abs() 求绝对值 例子 print(abs(-2)) all() 把序列中每一个元素做布尔运算,如果全部都是true,就返回true, 但是如果是空字符串.空列表也返回t ...

  7. Python之路(第五篇) Python基本数据类型集合、格式化、函数

    一.变量总结 1.1 变量定义 记录某种状态或者数值,并用某个名称代表这个数值或状态. 1.2 变量在内存中的表现形式 Python 中一切皆为对象,数字是对象,列表是对象,函数也是对象,任何东西都是 ...

  8. 【Python之路】特别篇--Python正则表达式

    正则表达式的基础 正则表达式并不是Python的一部分. 正则表达式是用于处理字符串的强大工具,拥有自己独特的语法以及一个独立的处理引擎,效率上可能不如str自带的方法,但功能十分强大. 得益于这一点 ...

  9. 【Python之路】特别篇--Python面向对象(进阶篇)

    上一篇<Python 面向对象(初级篇)>文章介绍了面向对象基本知识: 面向对象是一种编程方式,此编程方式的实现是基于对 类 和 对象 的使用 类 是一个模板,模板中包装了多个“函数”供使 ...

  10. Python之路(第七篇)Python作用域、匿名函数、函数式编程、map函数、filter函数、reduce函数

    一.作用域 return 可以返回任意值例子 def test1(): print("test1") def test(): print("test") ret ...

随机推荐

  1. 工具条OutLookBar

    工具条OutLookBar 灰姑娘本身也有自已的优点,但是却可能因为外貌不讨人喜欢,要变成白雪公主却需要有很多勇气和决心去改变自已: 有一颗善良的心 讨人喜爱的外貌 我这里讲的是一个工具条的蜕变过程, ...

  2. 软件设计师.NET认证考试测试卷(试题及答案)

    软件设计师.NET认证考试测试卷 注意事项:用蓝.黑色钢笔答题.保持卷面整洁. 得分 阅卷人 一.单项选择(40分,每小题1分) 1.以下标识符中不全是关键字的是(D  ) A.case for in ...

  3. ASP.NET Core + Angular 2 Template for Visual Studio

    多个月以来,我和多个Github上的社区贡献者一起建立支持库.包,我们最终的目的是希望完成这样一个作为起点的模板,也就是基于把Typescript代码和Angular2宿主在ASP.NET Core项 ...

  4. .Net程序员学用Oracle系列(2):准备测试环境

    <.Net程序员学用Oracle系列:导航目录> 本文大纲 1.创建说明 1.1.为什么要创建的测试环境? 1.2.了解 Oracle 实例的默认用户 2.创建环境 2.1.创建基本环境 ...

  5. BST 二叉搜索树

    定义: 二叉查找树要么是一棵空树,要么是一棵具有如下性质的非空二叉树:      1.若左子树非空,则左子树上的所有结点的关键字值均小于根结点的关键字值.      2.若右子树非空,则右子树上的所有 ...

  6. Python wifi掉线重连接

    原理很简单,通过python执行dos命令 : ping 和 netsh 需要用到os和time模块 代码如下: >>> import os >>> print ' ...

  7. 记一次kali和win8.1的双系统修复!!

    简要情况: 原来电脑存在的系统:win7和kali. 后来的系统:win8.1和原本的kali 情况描述:在我装完win8.1后就直接启动到win8.1了没有了grub2的选择启动界面,但是我还是想要 ...

  8. 自定义连接池java.lang.ClassCastException: com.sun.proxy.$Proxy4 cannot be cast to java.sql.Connection

    原因:Connection.getInterfaces() 与数据库驱动有关,数据库驱动不同 Connection.getInterfaces() 的结果也就不同,Connection.getInte ...

  9. oracle登录时shared memory realm does not exist的解决方法

    解决办法:1.用CMD进入命令行2.sqlplus /nolog 3.conn / as sysdba4.startup   然后用sqlplus进入命令  

  10. 【LeetCode】31. Next Permutation

    Implement next permutation, which rearranges numbers into the lexicographically next greater permuta ...