为了账号安全,请及时绑定邮箱和手机立即绑定

python进阶

廖雪峰 移动开发工程师
难度中级
时长 3小时33分
学习人数
综合评分9.20
575人评价 查看评价
9.6 内容实用
9.0 简洁易懂
9.0 逻辑清晰
def calc_prod(lst):
def calc():
s=1
for x in list:
s=s*x
return s
return calc
f = calc_prod([1, 2, 3, 4])
print f()
import math

def is_sqr(x):
return math.sqrt(x).is_integer()

print filter(is_sqr, range(1, 101))
import math

def add(x, y, f):
return f(x) + f(y)

print add(25, 9, math.sqrt
def count():
fs = []
for i in range(1, 4):
fs.append(lambda m=i : m**2)
return fs

f1, f2, f3 = count()
print f1(), f2(), f3()
class Fib(object):
def __call__(self,num):
a, b = 0, 1
for i in range(num):
print(b)
a, b = b, a + b

f = Fib()
f(10)
三种方法:
def format_name(s):
return s[:1].upper()+s[1:].lower()
print map(format_name, ['adam', 'LISA', 'barT'])

def format_name(s):
return s.capitalize()
print map(format_name, ['adam', 'LISA', 'barT'])

def format_name(s):
return s.title()
print map(format_name, ['adam', 'LISA', 'barT'])
class Person(object):
pass

p1 = Person()
p1.name = 'Bart'

p2 = Person()
p2.name = 'Adam'

p3 = Person()
p3.name = 'Lisa'

L1 = [p1, p2, p3]
L2 = sorted(L1,key=lambda x:x.name)

print L2[0].name
print L2[1].name
print L2[2].name
God,你离成神已经不远了!下一节吧。
# -*- coding: UTF-8 -*-
def __init__(self, name, score):
self.name = name
self._score = score
def get_grade(self):
if self._score>=90:
return "A"
elif self._score>=60 and self._score <90:
return "B"
else:
return "C"
import math


def is_sqr(x):
return math.sqrt(x) == int(math.sqrt(x))

a=list(filter(is_sqr, range(1, 101)))
print (a)
class Person(object):

__count = 0

@classmethod
def how_many(cls):
return cls.__count
def __init__(self, name):
self.name = name
Person.__count += 1

print Person.how_many()

p1 = Person('Bob')

print Person.how_many()
def format_name(s):
return s[:].title()

print map(format_name, ['adam', 'LISA', 'barT'])
默认升序:L2 = sorted(L1,key=lambda s:s.name)
设置降序:L2 = sorted(L1,key=lambda s:s.name,reverse=True)
@cnnlion
sorted([36,5,12,9,21],reversed_cmp)的执行过程:
5 < 36
[5, 36, 12, 9, 21]
12 > 5
[5, 12, 36, 9, 21]
12 < 36
[5, 12, 36, 9, 21]
12 > 5
[5, 12, 36, 9, 21]
9 < 12
[5, 9, 12, 36, 21]
9 > 5
[5, 9, 12, 36, 21]
21 > 12
[5, 9, 12, 21, 36]
21 < 36
[5, 9, 12, 36, 21]

#和排好序的列表中位数比较
def count():
fs = []
def freeze(fs,val):
fs.append(val)

for i in range(1, 4):
freeze(fs,i*i)
return fs
课程须知
本课程是Python入门的后续课程 1、掌握Python编程的基础知识 2、掌握Python函数的编写 3、对面向对象编程有所了解更佳
老师告诉你能学到什么?
1、什么是函数式编程 2、Python的函数式编程特点 3、Python的模块 4、Python面向对象编程 5、Python强大的定制类

微信扫码,参与3人拼团

意见反馈 帮助中心 APP下载
官方微信
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消