您现在所在的位置:首页 >学员就业 > 就业宝典 > Python 大神总结出来的10个经典面试题

Python 大神总结出来的10个经典面试题

来源:奇酷教育 发表于:

大神总结出的10个经典面试题。

  Python作为人类最有爱/最友爱的编程语言,可以胜任 AI 领域、Web 开发、GUI 开发、Office 操作、网络及爬虫、图形图像、树莓派、各类工具等等,同时开发效率非常高。

  因此,目前对Python工程师的需求量也是挺大的,下面就罗列出大神总结出的10个经典面试题。
 
  一、如何添加代码,使得没有定义的方法都调用 mydefault 方法?
 
  class A(object)
    def __init__(self, a, b):
      self.a1 = a
      self.b1 = b
    def mydefault(self):
      print 'default'
 
  a1 = A(10, 20)
  a1.fn1()
  a1.fn2()
  a1.fn3()
 
  答案:
  class A(object)
    def __init__(self, a, b):
      self.a1 = a
      self.b1 = b
      print 'init'
    def mydefault(self):
      print 'default'
    def __getattr__(self, name):
      return self.mydefault
 
  a1 = A(10, 20)
  a1.fn1()
  a1.fn2()
 
  此题考查的是 Python 的默认方法,只有当没有定义的方法调用时,才会调用方法 __getattr__ 。当 fn1 方法传入参数时,我们可以给 mydefault 方法增加一个 *args 不定参数来兼容。
 
  class A(object)
    def __init__(self, a, b):
      self.a1 = a
      self.b1 = b
      print 'init'
    def mydefault(self, *args):
      print 'default' + str(args[0])
    def __getattr__(self, name):
      print "other fn:",name
      return self.mydefault
 
  a1 = A(10, 20)
  a1.fn1(33)
  a1.fn2('hello')
 
 
  二、下面这段代码输出什么?
 
  num = 9
  def f1()
    num = 20
  def f2()
    print num
 
  f2()
  f1()
  f2()
 
  输出:
  > 9
  > 9
  此题考察全局变量和局部变量。num 不是个全局变量,所以每个函数都得到了自己的 num 拷贝,如果你想修改 num,则必须用 global 关键字声明。比如下面这样:
 
  num = 9
  def f1()
    global num
  num = 20
  def f2()
    print num
 
  f2()
  f1()
  f2()
 
  此时打印:
  > 9
  > 20
 
  三、写一个函数,接受整数参数 n,返回一个函数,函数返回 n 和参数的积。
  代码实现:
 
  def mulby(num):
    def gn(val):
      return num * val
    return gn
 
  zw = mulby(7)
  print(zw(9))
 
 
  四、请问如何修改以下 Python 代码,使得下面的代码调用类 A 的 show 方法?
 
  class A(object)
    def show(self):
      print 'base show'
 
  class B(A):
    def show(self):
      print 'derived show'
 
  obj = B()
  obj.show()
 
  解答:
  这道题考查的是类继承,只要通过 __class__ 方法指定类对象就可以了。补充的代码如下:
  obj.__class__ = A
  obj.show()
 
  五、下面这段代码的输出是什么?
 
  class B(object):
    def fn(self):
      print 'B fn'
    def __init__(self):
      print "B INIT"
 
  class A(object):
    def fn(self):
      print 'A fn'
 
    def __new__(cls, a):
      print "NEW", a
      if a > 10:
        return super(A, cls).__new__(cls)
      return B()
 
    def __init__(self, a)
      print "INIT", a
 
  a1 = A(5)
  a1.fn()
  a2 = A(20)
 
  解答:
  此题考查的是 new 和 init 的用法,使用 __new__ 方法,可以决定返回那个对象,也就是创建对象之前调用的,这个常见于设计模式的单例工厂模式。 __init__ 是创建对象时调用的。
 
 
  六、如何使用一行代码交换两个变量的值?
 
  a = 8
  b = 9
 
  解答:
 
  (a, b) = (b, a)
 
 
  七、下面这段代码输出是什么?
 
  ls = [1, 2, 3, 4]
  list1 = [i for i in ls if i > 2]
  print list1
 
  list2 = [i*2 for i in ls if i > 2]
  print list2
 
  dic1 = {x: x**2 for x in (2, 4,6)}
  print dic1
 
  dic2 = {x: 'item' + str(x**2) for x in (2, 4,6)}
  print dic2
 
  set1 = {x for x in 'hello world' if x not in 'low level'}
 
  解答:
  [3, 4]
  [6, 8]
  {2: 4, 4: 16, 6: 36}
  {2: 'item4', 4: 'item16', 6:'item36'}
  set(['h', 'r', 'd'])
 
  此题考查的是列表和字典的生成
 
 
  八、请问如何修改以下Python代码,使得代码能够运行?
 
  class A(object):
    def __init__(self, a, b)
      self.__a = a
      self.__b = b
    def myprint(self):
      print 'a=', self.__a, 'b=', self.__b
 
  a1 = A(10, 20)
  a1.myprint()
 
  a1(80)
 
  此题考查的是方法对象,为了能让对象实例能被直接调用,需要实现 __call__ 方法,补充代码如下:
  class A(object)
    def __init__(self, a, b):
      self.__a = a
      self.__b = b
    def myprint(self):
      print 'a=', self.__a, 'b=', self.__b
    def __call__(self, num)
      print 'call:'. num + self.a
 
 
  九、请问下面的代码有什么隐患?
 
  def strtest1(num):
    str = 'first'
    for i in range(num):
      str += "X"
    return str
 
  由于变量 str 是个不可变对象,每次迭代,Python 都会生成新的 str 对象来存储新的字符串,num 越大,创建的 str 对象越多,内存消耗越大。
 
 
  十、一个包里有三个模块,mod1.py , mod2.py , mod3.py ,但使用 from demopack import * 导入模块时,如何保证只有 mod1 、 mod3 被导入了
 
  在包中增加 __init__.py 文件,并在文件中添加:
  __all__ = ['mod1', 'mod3']