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

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

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

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

若是总是以为碰到循环引用可能的缘由有几点:程序员

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

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

采起办法,从设计模式上来规避这个问题,好比:编程

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

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

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

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

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

装饰器本质上是一个Python函数,它可让其余函数在不须要作任何代码变更的前提下增长额外功能,装饰器的返回值也是一个函数对象。app

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

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

第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')

第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"))

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

更多内容,欢迎关注 https://dwz.cn/r4lCXEuL

在这里插入图片描述

相关文章
相关标签/搜索