面试题(一)
1、现有两元祖 (('a'),('b'),('c'),('d') ) ,请使用Python中的匿名函数生成列表 [ {'a':'c',{'c':'d'}]
答案:v = list(map(lambda x,y:{x:y},data[0:2],data[2:4])) data = (('a'),('b'),('c'),('d') ) v = list(map(lambda x,y:{x:y},data[0:2],data[2:4])) data[0:2] = ('a'),('b') data[2:4] = ('c'),('d') 匿名函数 传进去 参数(x,y) 返回 {x:y} map(func,iterable) # 对于iterable 依次 传递给 func ,返回的是可迭代对象
2、看代码 写结果
def multipliters(): return [lambda x:i * x for i in range(4)] print([m(2) for m in multipliters()])
# 第一种是 将生成器对象生成的匿名函数转化成列表 ,匿名函数使用的是相同的内存空间。 # 转换成列表后,循环结束,命名空间里的i都为3 def multipliters(): return [lambda x:i * x for i in range(4)] print([m(2) for m in multipliters()]) # 以下是依次返回 生成器生成的每个匿名函数,每次调用i都在变化 def multipliters2(): return (lambda x: i*x for i in range(4)) print([m(2) for m in multipliters2()])
3、 1 or 2 和 1 and 2 分别输出什么?
# 1 2 # 0 "" [] {} set() None False 放入判断表达式都为假 # or 或 and 与 # 整个式子 不断去向右查看,直到能确定为真就停下来
4、看代码 写结果
value = "B" and "A" or "C" print(value)
# A # 整个式子 不断去向右查看,直到能确定为真就停下来
5、看代码写结果
v1 = [i % 2 for i in range(10)] v2 = (i % 2 for i in range(10)) print(v1,v2)
# v1 = [i % 2 for i in range(10)] 为列表生成式 # v2 = (i % 2 for i in range(10)) 为<generator object <genexpr> at 0x00E4F990>为生成式
6、看代码,写结果
def extendList(val,li=[]): li.append(val) return li list1 = extendList(10) list2 = extendList(123,[]) list3 = extendList('a') print(list1) print(list2) print(list3)
# [10, 'a'] # [123] # [10, 'a'] # 参数变量在编译会生成,而且只会生成一次,其内存地址的指向不发生变化 # 所以会有默认的 [] # 1、3都会使用默认的 编译生成同一个[] # 2 新生成一个 []
7、下面代码谁报错?
v1 = {} v2 = {3:5} v3 = {[11,23]:5} v4 = {(11,23):5}
v3错误,字典元素的键不能为可变对象
8、输出以下结果
for i in range(5,0,1): print(i)
# range(起始元素,结束元素(不包含),每次的变化) # 5 每次加1,啥时候能加到0,O(∩_∩)O哈哈~
9、请说出range和xrange的区别
# from collections import Iterable,Iterator # Iterable 可迭代对象 # Iterator 迭代器 # print(isinstance(xrange(10),Iterator)) # print(isinstance(xrange(10),Iterable)) # python2 中 range(start, stop[, step]) 和 range(stop) 会生成-> range object,,返回是列表,是可迭代对象,全部放在内存里 # python2 中 xrange(start, stop[, step]) 和 range(stop)会生成-> xrange object,返回是可迭代对象,每次调用时才会生成 # python3 没有xrange,只有range,也是可迭代对象,每次调用时才会生成
10、请将 "1,2,3",变成 ["1","2","3"]
"1,2,3".split(',')
11、一行代码生成 [1,4,9,16,25,36,49,64,81,100]
[i*i for i in range(11)]
12、一行生成 9 * 9乘法表
[ x for x in range(1,10)] [ x*y for y in range(1,x+1)] [ ([ x*y for y in range(1,x+1)]) for x in range(1,10)] [ ([ '{}*{} = {}'.format(x,y,x*y) for y in range(1,x+1)]) for x in range(1,10)] '\n'.join([ str(x) for x in range(1,10)]) print('\n'.join([ ' '.join( [ '{}*{} = {}'.format(x,y,x*y) for y in range(1,x+1)] ) for x in range(1,10)]) )
13、map(str,[1,2,3,4,5,6,7,8,9])输出什么?Python2 和Python3输出的结果一样吗?
print(isinstance(map(str,[1,2,3,4,5,6,7,8,9]),Iterable)) print(isinstance(map(str,[1,2,3,4,5,6,7,8,9]),Iterator)) # python 3 <map object at 0x00D359F0> 是 Iterator # python 2 ['1', '2', '3', '4', '5', '6', '7', '8', '9'] ,是可迭代对象,但不是Iterator
14、Django如何在Model保存前做一定的固定操作,比如写一条日志
利用Django的Model的Signal Dispatcher, 通过django.db.models.signals.pre_save()方法,在事件发生前,发射触发信号,这一切都被调度中的receiver方法深藏功与名的保存了。 信号的处理一般都写在Model中,举个例子: import logging from django.db import models from django.db.models.signals import pre_save from django.dispatch import receiver class Order(models.Model): # ... logger = logging.getLogger(__name__) @receiver(pre_save, sender=Order) def pre_save_handler(sender, **kwargs): # 我们可以在Order这个Model保存之前尽情调戏了:) logger.debug("{},{}".format(sender, **kwargs))
参考:http://python.jobbole.com/81871/
15、1,2,3,4,5能组成多少个互不相同的无重复的三位数
5 * 4 * 3
答案:
人,从刚出生来到这个世界,便开始探索这个世界。累了就歇会,精神了就继续探索,直至死亡。