哦?原来Python 面试题是这样的,Python面试题No19

举报
梦想橡皮擦 发表于 2021/05/26 22:59:06 2021/05/26
【摘要】 文章目录 本面试题题库,由公号:非本科程序员 整理发布第1题:是否遇到过python的模块间循环引用的问题,如何避免它?第2题:简单介绍一下python函数式编程?第3题:python中函数装饰器有什么作用?第4题: 按照要求完成编码?第5题:按照要求完成编码?第6题:关注题,最近在公号更新一个神奇的系列入门文章 本面试题题库,由公号:非本科程序员 整...

本面试题题库,由公号:非本科程序员 整理发布

第1题:是否遇到过python的模块间循环引用的问题,如何避免它?

这是代码结构设计的问题,模块依赖和类依赖

如果老是觉得碰到循环引用可能的原因有几点:

  1. 可能是模块的分界线划错地方了
  2. 可能是把应该在一起的东西硬拆开了
  3. 可能是某些职责放错地方了
  4. 可能是应该抽象的东西没抽象

总之微观代码规范可能并不能帮到太多,重要的是更宏观的划分模块的经验技巧,推荐uml,脑图,白板等等图形化的工具先梳理清楚整个系统的总体结构和职责分工

采取办法,从设计模式上来规避这个问题,比如:

  1. 使用 “__all__” 白名单开放接口
  2. 尽量避免 import

第2题:简单介绍一下python函数式编程?

在函数式编程中,函数是基本单位,变量只是一个名称,而不是一个存储单元。

除了匿名函数外,Python还使用fliter(),map(),reduce(),apply()函数来支持函数式编程。
所以你的重点围绕fliter(),map(),reduce().apply()来介绍就可以顺利和面试官达成一致

第3题:python中函数装饰器有什么作用?

装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。

它经常用于有切面需求的场景,比如:
插入日志性能测试事务处理缓存权限校验等场景。

有了装饰器,就可以抽离出大量与函数功能本身无关的雷同代码并继续重用。

第4题: 按照要求完成编码?

写一个函数,将两个dict(key是数字,value是string)进行合并,函数返回合并后的dict。
规则如下:如果一个key仅仅存在于其中一个dict中,则直接加入合并后的dict;
如果一个key在两个dict中都存在,那么给定一个choice值,choice可以是任何string,如果choice是任一个dict中的value,则写入,否则不写入。

代码如下

def function(lefdict,rightdict,choice): samelist=lefdict.keys() & rightdict.keys()  # dict.keys()返回的是一个可迭代对象,取两个dict的keys的交集 diflist = lefdict.keys() ^ rightdict.keys() # 取两个dict的keys的不同集 newdict={} for key,value in lefdict.items(): if key in diflist: newdict[key]=value elif key in samelist: if value==choice: newdict[key]=value for key,value in rightdict.items(): if key in diflist: newdict[key]=value elif key in samelist: if value==choice: newdict[key]=value print(samelist,diflist) print(newdict) return newdict function({1:'a',2:'b',3:'c'},{4:'f',2:'b',3:'d'},'b')

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

第5题:按照要求完成编码?

把一个字符串的尾字母移到首位,比如‘abcde’->‘eabcd’,称为一次字符串的旋转。如果字符串1的任何一次旋转可以包含字符串2,则返回true,否则返回false,请写一个函数实现。

代码如下

def function(str1, str2): str1 = str1[-1] + str1[:-1] print(str1) if str1.find(str2) != -1: return True else: return False


print(function("abcde", "cde"))

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

第6题:关注题,最近在公号更新一个神奇的系列入门文章

更多内容,欢迎关注

在这里插入图片描述

文章来源: dream.blog.csdn.net,作者:梦想橡皮擦,版权归原作者所有,如需转载,请联系作者。

原文链接:dream.blog.csdn.net/article/details/89961067

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。