强烈推荐:春招面试,看这110道Python面试题就够了!(3)
filter() 函数用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。该接收两个参数,第一个为函数,第二个为序列,序列的每个元素作为参数传递给函数进行判,然后返回 True 或 False,最后将返回 True 的元素放到新列表 28、列表推导式求列表所有奇数并构造新列表,a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] 29、正则re.complie作用 re.compile是将正则表达式编译成一个对象,加快速度,并重复使用 30、a=(1,)b=(1),c=("1") 分别是什么类型的数据? 31、两个列表[1,5,7,9]和[2,2,6,8]合并为[1,2,2,3,6,7,8,9] extend可以将另一个集合中的元素逐一添加到列表中,区别于append整体添加 32、用python删除文件和用linux命令删除文件方法 python:os.remove(文件名) linux: rm 文件名 33、log日志中,我们需要用时间戳记录error,warning等的发生时间 请用datetime模块打印当前时间戳 “2018-04-01 11:38:54” 顺便把星期的代码也贴上了 34、数据库优化查询方法 外键、索引、联合查询、选择特定字段等等 35、请列出你会的任意一种统计图(条形图、折线图等)绘制的开源库 第三方也行 pychart、matplotlib 36、写一段自定义异常代码 自定义异常用raise抛出异常 37、正则表达式匹配中,(.*)和(.*?)匹配区别? (.*)是贪婪匹配,会把满足正则的尽可能多的往后匹配 (.*?)是非贪婪匹配,会把满足正则的尽可能少匹配 38、简述Django的orm ORM,全拼Object-Relation Mapping,意为对象-关系映射 实现了数据模型与数据库的解耦,通过简单的配置就可以轻松更换数据库,而不需要修改代码只需要面向对象编程,orm操作本质上会根据对接的数据库引擎,翻译成对应的sql语句,所有使用Django开发的项目无需关心程序底层使用的是MySQL、Oracle、sqlite....,如果数据库迁移,只需要更换Django的数据库引擎即可 39、[[1,2],[3,4],[5,6]]一行代码展开该列表,得出[1,2,3,4,5,6] 列表推导式的骚操作 运行过程:for i in a ,每个i是【1,2】,【3,4】,【5,6】,for j in i,,每个j就是1,2,3,4,5,6,合并后就是结果 还有更骚的方法,将列表转成numpy矩阵,通过numpy的flatten()方法,代码永远是只有更骚,没有最骚 40、x="abc",y="def",z=["d","e","f"],分别求出x.join(y)和x.join(z)返回的结果 join()括号里面的是可迭代对象,x插入可迭代对象中间,形成字符串,结果一致,有没有突然感觉字符串的常见操作都不会玩了 顺便建议大家学下os.path.join()方法,拼接路径经常用到,也用到了join,和字符串操作中的join有什么区别,该问题大家可以查阅相关文档,后期会有答案 41、举例说明异常模块中try except else finally的相关意义 try..except..else没有捕获到异常,执行else语句 try..except..finally不管是否捕获到异常,都执行finally语句 (编辑:ASP站长网) |