Python 大神总结出来的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)#p#分页标题#e#
  
  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):#p#分页标题#e#
  
  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']