Python求职怎么拿到对折面试公司Offer

找工做,历来都不是一件容易的事——无数的身负绝技的工程师在面试中折戟,拿不到想要的offer,得不到想要的职位。可是,却有这么一我的,在短短的几天时间里,面试成功率超过五成,到手offer拿到手软,这是为何呢?

从八月底开始找工做,短短的一星期多一些,面试了9家公司,拿到5份Offer,多是由于我所面试的公司都是些创业性的公司吧,不过仍是感触良多,由于学习python的时间还很短,没想到还算比较容易的找到了工做,就把这些天的面试经验和你们分享一下,但愿为学习python找工做的小伙伴们提供些许帮助。python

笔者感受面试最主要的两点:1.项目经验。 2.项目经验和招聘职位相符,这是最主要的,其余的都是锦上添花。web

常规问题
自我介绍

这是一道送分题,万年不变的第一个问题。不过有些小伙伴可能没有太在乎,其实这个问题已经在面试官心中决定了你的去留意向。自我介绍的主要结构:我的基本信息 + 基本技术构成 + 项目经验(具体项目以及在项目中的负责部分)+ 自我评价,其中的原则就是牢牢围绕招聘岗位的需求作介绍。在此以前要作好准备工做,看看招聘方具体须要什么方向的研发工程师。目前针对Python,拉勾上的招聘多为自动化测试平台的设计与开发、数据的挖掘与清洗。单纯的web开发好像尚未,因此web方向的同窗注意,多和运维以及自动化方面靠拢。面试

二段式询问

在面试的过程中,在面试官提出问题的时候,每每会就问题自己引伸出较深层次的问题。好比:你使用过with语句吗?个人回答是:with语句常常适用于对资源进行访问的场合,确保在访问的过程当中无论是否发生异常都会指执行必要的清理操做,好比文件的自动关闭以及线程中锁的自动获取与释放。面试官紧接着问,那你知道为何with语句可以使文件正确关闭,一会儿把我问闷了,只能依稀记得with语句会开辟出一块独立环境来执行文件的访问,相似沙盒机制。面试官对这个答案不置能否,算是勉强经过了。因此知其然更要知其因此然。在平时的学习中,多问一个为何,面试的时候就不会太被动。算法

不要给本身挖坑

确保你在回答面试官的过程当中,回答中的每一个知识点都了然于胸,否则被问住,是很难堪的。我在回答web安全问题时,顺嘴说了SQL注入,面试官说既然提到了SQL注入,那么你讲讲它的原理及解决方法吧!丢脸的是我居然把XSS跨站注入攻击和SQL注入搞混了,场面也是有点尴尬。因此斟酌你说的每一句话,聪明点的同窗还能够引导面试官,让他问出本身想要被问的问题。数据库

这一年你学习了什么新的技能

这是面试官在考察你是否对于新鲜技术抱有极大热忱。面试个人面试官无一例外都问到了这个问题。他们都但愿能找一个不断学习,开括创新的年轻人。多浏览最新的技术资讯,选择一方面本身感兴趣的领域。编程

选择创业公司仍是大公司,为何?

固然是看招聘方属于哪个公司啦,不过问这种问题的通常都是创业公司。答案无非是:挑战大,享受挑战;创业公司具备无限成功的可能性,想随公司一块儿成长;数组

为何你要从上一家公司离职?

这也是一个必问问题,找一个比较正当的理由,不要说什么公司零食太多胖了20斤,公司周别附近的外卖都吃腻了,真的别这样说…主要原则就是不要对前公司抱有怨言,BOSS朝令夕改,PM不靠谱什么的,多寻找自身缘由:公司发展比较稳定,但我还年轻,但愿有更大的挑战和更多的学习机会。像这样就能够。缓存

描述一下你的上一家公司

这个问题问到的概率不太大,不过也仍是有三家公司问到过,招聘方主要想从上一家公司的具体经营规模以及主营业务来定位你的水平,知道招聘方的目的就能够从容应答。安全

技术性问题

非技术性的问题就是以上这么多,做为参考稍加准备,面试的时候就能对答如流。下面讲一下在面试中的技术性问题。我的感受技术性的问题面试官问的没有特别多,通常考察2-3个,由浅到深。数据结构

简述函数式编程

在函数式编程中,函数是基本单位,变量只是一个名称,而不是一个存储单元。除了匿名函数外,Python还使用fliter(),map(),reduce(),apply()函数来支持函数式编程。

什么是匿名函数,匿名函数有什么局限性

匿名函数,也就是lambda函数,一般用在函数体比较简单的函数上。匿名函数顾名思义就是函数没有名字,所以不用担忧函数名冲突。不过Python对匿名函数的支持有限,只有一些简单的状况下可使用匿名函数。

如何捕获异常,经常使用的异常机制有哪些?

若是咱们没有对异常进行任何预防,那么在程序执行的过程当中发生异常,就会中断程序,调用python默认的异常处理器,并在终端输出异常信息。

try…except…finally语句:当try语句执行时发生异常,回到try语句层,寻找后面是否有except语句。找到except语句后,会调用这个自定义的异常处理器。except将异常处理完毕后,程序继续往下执行。finally语句表示,不管异常发生与否,finally中的语句都要执行。

assert语句:判断assert后面紧跟的语句是True仍是False,若是是True则继续执行print,若是是False则中断程序,调用默认的异常处理器,同时输出assert语句逗号后面的提示信息。

with语句:若是with语句或语句块中发生异常,会调用默认的异常处理器处理,但文件仍是会正常关闭。

copy()与deepcopy()的区别

copy是浅拷贝,只拷贝可变对象的父级元素。 deepcopy是深拷贝,递归拷贝可变对象的全部元素。

函数装饰器有什么做用(常考)

装饰器本质上是一个Python函数,它可让其余函数在不须要作任何代码变更的前提下增长额外功能,装饰器的返回值也是一个函数对象。它常常用于有切面需求的场景,好比:插入日志、性能测试、事务处理、缓存、权限校验等场景。有了装饰器,就能够抽离出大量与函数功能自己无关的雷同代码并继续重用。

简述Python的做用域以及Python搜索变量的顺序

Python做用域简单说就是一个变量的命名空间。代码中变量被赋值的位置,就决定了哪些范围的对象能够访问这个变量,这个范围就是变量的做用域。在Python中,只有模块(module),类(class)以及函数(def、lambda)才会引入新的做用域。Python的变量名解析机制也称为 LEGB 法则:本地做用域(Local)→当前做用域被嵌入的本地做用域(Enclosing locals)→全局/模块做用域(Global)→内置做用域(Built-in)

新式类和旧式类的区别,如何确保使用的类是新式类

为了统一类(class)和类型(type),python在2.2版本引进来新式类。在2.1版本中,类和类型是不一样的。

为了确保使用的是新式类,有如下方法:

放在类模块代码的最前面 __metaclass__ = type
从内建类object直接或者间接地继承
在python3版本中,默认全部的类都是新式类。

简述__new__和__init__的区别

建立一个新实例时调用__new__,初始化一个实例时用__init__,这是它们最本质的区别。

new方法会返回所构造的对象,init则不会.

new函数必须以cls做为第一个参数,而init则以self做为其第一个参数.

Python垃圾回收机制(常考)

Python GC主要使用引用计数(reference counting)来跟踪和回收垃圾。在引用计数的基础上,经过“标记-清除”(mark and sweep)解决容器对象可能产生的循环引用问题,经过“分代回收”(generation collection)以空间换时间的方法提升垃圾回收效率。

1 引用计数

PyObject是每一个对象必有的内容,其中ob_refcnt就是作为引用计数。当一个对象有新的引用时,它的ob_refcnt就会增长,当引用它的对象被删除,它的ob_refcnt就会减小.引用计数为0时,该对象生命就结束了。

优势:

简单 实时性 缺点:

维护引用计数消耗资源 循环引用

2 标记-清除机制

基本思路是先按需分配,等到没有空闲内存的时候从寄存器和程序栈上的引用出发,遍历以对象为节点、以引用为边构成的图,把全部能够访问到的对象打上标记,而后清扫一遍内存空间,把全部没标记的对象释放。

3 分代技术

分代回收的总体思想是:将系统中的全部内存块根据其存活时间划分为不一样的集合,每一个集合就成为一个“代”,垃圾收集频率随着“代”的存活时间的增大而减少,存活时间一般利用通过几回垃圾回收来度量。

Python默认定义了三代对象集合,索引数越大,对象存活时间越长。

property有什么做用?如何实现成员变量的只读属性?

@property装饰器就是负责把一个方法变成属性调用,一般用在属性的get方法和set方法,经过设置@property能够实现实例成员变量的直接访问,又保留了参数的检查。另外经过设置get方法而不定义set方法能够实现成员变量的只读属性。

*args and **kwargs

*args表明位置参数,它会接收任意多个参数并把这些参数做为元组传递给函数。**kwargs表明的关键字参数,容许你使用没有事先定义的参数名,另外,位置参数必定要放在关键字参数的前面。

with statement的好处是什么?具体如何实现?

with语句适用于对资源进行访问的场合,确保无论使用过程当中是否发生异常都会执行必要的“清理”操做,释放资源,好比文件使用后自动关闭、线程中锁的自动获取和释放等。

what will be the output of the code below?

def extend_list(val, list=[]):
list.append(val)
return list

list1 = extend_list(10)
list2 = extend_list(123, [])
list3 = extend_list(‘a’)

print(list1) # list1 = [10, ‘a’]
print(list2) # list2 = [123, []]
print(list3) # list3 = [10, ‘a’]

class Parent(object):
x = 1

class Child1(Parent):
pass

class Child2(Parent):
pass

print(Parent.x, Child1.x, Child2.x) # [1,1,1]
Child1.x = 2
print(Parent.x, Child1.x, Child2.x) # [1,2,1]
Partent.x = 3
print(Parent.x, Child1.x, Child2.x) # [3,2,3]

数组问题

在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数。

arr = [[1,4,7,10,15], [2,5,8,12,19], [3,6,9,16,22], [10,13,14,17,24], [18,21,23,26,30]]

def getNum(num, data=None):
while data:
if num > data[0][-1]:
del data[0]
print(data)
getNum(num, data=None)
elif num < data[0][-1]:
data = list(zip(*data))
del data[-1]
data = list(zip(*data))
print(data)
getNum(num, data=None)
else:
return True
data.clear()
return False

if __name__ == ‘__main__’:
print(getNum(18, arr))

获取最大公约数、最小公倍数

a = 36
b = 21

def maxCommon(a, b):
while b: a,b = b, a%b
return a

def minCommon(a, b):
c = a*b
while b: a,b = b, a%b
return c//a

if __name__ == ‘__main__’:
print(maxCommon(a,b))
print(minCommon(a,b))

获取中位数
def median(data):
data.sort()
half = len(data) // 2
return (data[half] + data[~half])/2

l = [1,3,4,53,2,46,8,42,82]

if __name__ == ‘__main__’:
print(median(l))

整数问题

输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。

def getOneCount(num):
if num > 0:
count = b_num.count(‘1’)
print(b_num)
return count
elif num < 0:
b_num = bin(~num)
count = 8 – b_num.count(‘1’)
return count
else:
return 8

if __name__ == ‘__main__’:
print(getOneCount(5))
print(getOneCount(-5))
print(getOneCount(0))

以上就是我面试过程当中所被问到的问题,算法题仍是比较少的,也只有2家公司要求写算法,数据结构彷佛被问到的不是特别多,就问到了一个B+树的结构。数据库问到的是索引相关的优化。稍微有些基础的都能回答上来,可是最好能够深层次的探讨一下。

本文只作抛砖引玉之用,有些看法还不是特别成熟,但愿能够为学习Python找工做的伙伴们提供一些帮助,面试过程中最重要的一点是放平心态,求职过程是双方的,不须要太过紧张,把本身掌握的知识充分表达出来就好。只要你是匹千里马,早晚会被伯乐牵出来遛一遛的。

看完这篇文章,你有没有对本身的求职之路增长一些信心呢?

参考咱们文章中提到的内容,针对性的调整本身的面试策略,将本身的知识最完美的呈现出来,不光是为了面试,也是为了让本身的才华有用武之地。

相关文章
相关标签/搜索