Python面试基础整理

  1. Python可变类型与不可变类型
    不可变类型:数字、字符串、元组
    可变类型:列表、字典、集合
  2. 浅拷贝和深拷贝
    浅拷贝:新旧对象共享一块内存,拷贝父对象,不拷贝对象内部的子对象
    深拷贝:为数据重新开辟一块空间,修改新对象不会改变原对象
import copy
#浅拷贝
arr=[1,2,3,[4,5,6]]
arr2=arr.copy()
arr2[0]=10
arr2[3][0]=40
print(arr)#[1, 2, 3, [40, 5, 6]]
print(arr2)#[10, 2, 3, [40, 5, 6]]
    
arr=[1,2,3,[4,5,6]]
arr3=arr[:]
arr3[0]=10
arr3[3][0]=40
print(arr)#[1, 2, 3, [40, 5, 6]]
print(arr3)#[10, 2, 3, [40, 5, 6]]
    
arr=[1,2,3,[4,5,6]]
arr4=copy.copy(arr)
arr4[0]=10
arr4[3][0]=40
print(arr)#[1, 2, 3, [40, 5, 6]]
print(arr4)#[10, 2, 3, [40, 5, 6]]
    
#深拷贝
arr=[1,2,3,[4,5,6]]
arr5=copy.deepcopy(arr)
arr5[0]=10
arr5[3][0]=40
print(arr)#[1, 2, 3, [4, 5, 6]]
print(arr5)#[10, 2, 3, [40, 5, 6]]
  1. Python字符串去重并排序
s='abcabcefefabczzx'
s=list(s)   #转成列表
s=set(s)    #去重
s=list(s)   #转回列表
s.sort()    #排序
s=''.join(s)#转回字符串
print(s)    #输出:abcefxz
  1. Python交换两个变量的值
a='abc'
b='cdf'
a,b=b,a
print(a,b) #输出:cdf abc
  1. Python提取列表中的数字
s=[123,'a','b',234,2,5,'abc']
s=list(filter(lambda x:type(x)==int,s))
print(s)
  1. pip是什么?
    python包管理器/模块管理器
  2. pip常用指令
    pip list
    pip install
    pip uninstall
  3. 隔离环境的目的
    为了让每个应用有独立的运行环境
  4. pyhton中的注释
    单行#注释,
    多行```注释``,
    """注释"""
  5. python2.x和python3.x的区别
    1. 编码
      python2.x默认ASCII 要加# -*- coding:UTF-8
      python3.x默认unicode
    2. print
      print加不加括号的区别
    3. input
      2.x input返回数值类型
      raw_input返回字符串类型
      3.x input返回字符串类型
    4. range
      2.x 返回列表
      3.x 返回迭代器
  6. 多行语句用\隔开,或者()
  7. 为什么很多人说python弱类型?
    声明不需要指定,表面弱类型,实际很严格
  8. python中的数据类型
    在python中常用的数据类型:数值 字符串 列表 元组 字典 集合
    在python中有多少种数据类型:除了以上标准的,还有int long float bool等
  9. type()返回的结果是什么?
    如果只有第一个参数,返回对象的类型,如果有三个参数返回新的类型对象
  10. isinstance() 与 type() 区别
    type() 不认为子类是一种父类类型,不考虑继承关系
    isinstance() 会认为子类是一种父类类型,考虑继承关系
  11. int(1.4)和int('1.4')什么结果?
    int(1.4)结果:1,int('1.4')报错
  12. 保留两位小数round(m,2),a=3.1415926保留两位小数
a=3.175
print('%.2f'%a)
b=round(a,2)#四舍五入,小数点后奇数+5不进1,偶数+5进1
print(b)
def num2(n):
    arr = str(n).split('.')
    point = arr[1][0:2]
    num = arr[0] + '.' + point
    return num
    a=num2(1.12212)
    print(a)
  1. bool类型
print(bool('False'))#True
print(bool(0))#False
print(bool([1,2]))#True
print(bool([]))#False
print(bool({}))#False
print(bool(None))#False
  1. set类型
a={}
b=set()
c={1}
print(type(a))#<class 'dict'>
print(type(b))#<class 'set'>
print(type(c))#<class 'set'>
  1. repr(x)的区别str(x)
    数值、列表、字典输出相同
    repr(x)便于编译理解,转成表达式字符串
    str(x)便于程序员理解,转成字符串
a='hello\n'
print(str(a))   #hello+换行
print(repr(a))  #'hello\n'
a='1000L'
print(str(a))   #1000L
print(repr(a))  #'1000L'
#1000L长整型
  1. 哪些是可变类型,哪些是不可变类型,区别是什么
    可变:列表,字典,集合
    不可变:元组,字符串,数值
arr=[1,2,3,4]
s='abcd'
arr[1]=20
print(arr) #[1, 20, 3, 4]
s[1]='d'   #TypeError: 'str' object does not support item assignment
print(arr)
  1. s=r'\n' 字符串前加r与普通字符串几乎相同的语法
  2. 切片
    1. 第一个 s[0]
    2. 最后一个 s[-1]
    3. 2-4 s[1:4]
    4. 2-最后 s[a:]
    5. 步长2 s[1:10:2]
    6. 字符串反转 s[::-1]
  3. 内建函数
    1. count()统计一个字符串出现的次数
    2. find()检测字符串中是否包含子串,有返回索引值,否则返回-1
    3. replace()替换
  4. 去空格
s='  abc def   '
print('**'+s.lstrip()+'**')#**abc def   **
print('**'+s.rstrip()+'**')#**  abc def**
print('**'+s.strip()+'**')#**abc def**
print('**'+s.replace(' ','')+'**')#**abcdef**
import re
s='  abc def   '
s=re.sub(r'\s','',s)
print('**'+s+'**')
  1. split()字符串拆分成数组
  2. join()数组拼合并成字符串
s1='abc'
s2='123'
s3=['x','y','z']
print(s1.join(s2))
print(s1.join(s3))
  1. 判断
    1. isdigit()判断是否是纯数字
    2. isalpha()判断是否是纯字母
    3. isalnum()判断是否是字母或数字
    4. upper()转大写
s1='123'
s2='abc'
s3='abc123'
print(s1.isdigit())#True
print(s2.isalpha())#True
print(s3.isalnum())#True
  1. 列举常用的五个模块
    os,re,math,datetime,urllib,request
  2. dir()和help()
    dir()不带参数时,返回当前范围内的变量、方法和定义的类型列表
    dir()带参数时,返回参数的属性、方法列表
    help()查看函数或模块用途的详细说明
  3. 取整
    floor()向下取整
    ceil()向上取整
    trunc()截断小数位
import math
a=1.345
b=-1.567
print(int(a))#1
print(math.floor(a))#1
print(math.ceil(a))#2
print(int(b))#-1
print(math.floor(b))#-2
print(math.ceil(b))#-1
print(math.trunc(a))#1
  1. 随机排序
import random
arr=[1,2,3]
random.shuffle(arr)
print(arr)
  1. 列表
    count()判断是否存在
    append()添加元素
    extend()增加集合
    insert()插入元素
    remove()删除一个具体元素
    del 删除一个具体元素
    clear()清空
    append+pop()栈
    append+popleft队列
  2. 判断是否存在
s='abcd'
print(s.count('a'))#1找不到不会报错
print(s.index('a'))#0找不到会报错
print(s.find('a'))#0
print('a' in s)#True
  1. 列表
    sort()
    reverse()
  2. 内置函数
    map
    filter
    reduce
    sorted
  3. 列表推导式
    取偶数
arr = [1, 2, 6, 3, 1]
arr2 = [i for i in arr if i % 2 == 0]
print(arr2)

二维转一维

arr=[[1,2,3],[4,5,6],[7,8,9]]
arr2=[]
for i in arr:
    for j in i:
        arr2.append(j)
print(arr2)
arr=[[1,2,3],[4,5,6],[7,8,9]]
arr2=[i for j in arr for i in j]
print(arr2)#[1, 2, 3, 4, 5, 6, 7, 8, 9]

按列取

arr=[[1,2,3],[4,5,6],[7,8,9]]
arr2=[[e[i] for e in arr] for i in range(len(arr))]
print(arr2)#[[1, 4, 7], [2, 5, 8], [3, 6, 9]]
  1. 查看地址
arr=[1,2,3]
print(id(arr))
  1. 垃圾回收机制
    1. 小对象对象池
      • -5-256
      • 数字字母下划线
      • 长度不能大于20
      import sys
      print(sys.getrefcount(3))
      a=3
      print(sys.getrefcount(3))
      b=3
      print(sys.getrefcount(3))
      
    2. 大对象对象池
      • 作用域内部才等
      • python中引用计数器如果是0,垃圾回收机制把它扫掉
  2. 垃圾回收
    c、c++用户自己管理维护内存
    java,c#垃圾回收机制
    python的垃圾回收机制采用引用计数器
    ruby:标记删除
    优点:实时性 处理回收内存时间分摊到平时
    缺点:维护引用计数器耗资源
    垃圾回收机制工作:为新生的对象分配内存,识别垃圾,清理垃圾
  3. 字典的遍历
    goods={
    "id":'001',
    "price":20
}
for i in goods:
    print(i)
    #id
    #price
for k,v in goods.items():
    print(k,v)
    # id 001
    #price 20
for k in goods.keys():
    print(k)
    #id
    #price
for v in goods.values():
    print(v)
    #001
    #20
  1. get()
goods={
    "id":'001',
    "price":20
}
print(goods.get('id'))#001
  1. pop()
goods={
    "id":'001',
    "price":20
}
goods.pop('id')
print(goods)#{'price': 20}
  1. 字典的合并
goods={
    "id":'001',
    "price":20
}
goods2={
    "num":9
}
goods.update(goods2)
print(goods)#{'id': '001', 'price': 20, 'num': 9}
  1. 字典字符串转换
import json
json.dumps(dict)#字典->字符串
json.loads(str)#字符串->字典
  1. 元组
    一旦创建不可改变,但可以切片
arr=(1,2,3)
a,*b=arr
print(type(a))#<class 'int'>
print(type(b))#<class 'list'>
  1. 集合
    不重复
s={1,2,3,3,3,3,3}
print(s)#{1, 2, 3}

添加add()

s={1,2,3}
s.add(4)
print(s)#{1, 2, 3, 4}

移除discard()、remove()、pop()

s={1,2,3}
s.discard(2)
print(s)#{1, 3}
s.discard(4)#移除不存在的元素不会报错
s={1,2,3}
s.remove(2)
print(s)#{1, 3}
s.remove(4)#KeyError: 4
  1. 交集、并集
    intersection()
    union()
  2. 合并并更新
    update()
  3. zip()迭代器
s=['a','b','c']
s2=[1,2,3]
s3=zip(s,s2)
print(list(s3))#[('a', 1), ('b', 2), ('c', 3)]
  1. enumerate()
s=['a','b','c']
for (index,item) in enumerate(s):
    print(index,item)
#0 a
#1 b
#2 c
print(list(enumerate(s)))#[(0, 'a'), (1, 'b'), (2, 'c')]
  1. 迭代器
    字符串/数组本身没有迭代对象,for循环自动加上迭代器
s='hi cat'
i=iter(s)
print(i.__next__())#h
print(i.__next__())#i
print(i.__next__())#
print(i.__next__())#c
print(i.__next__())#a
print(i.__next__())#t
  1. 生成器
  • 推导式写成()
  • yield
L=[x*x for x in range(10)]
G=(x*x for x in range(10))
print(L[-1])#81
while True:
    try:
        print(G.__next__())
    except StopIteration:
        break
  1. 可选参数、关键字参数
def add(a,b=2,*c):
    print(c)
add(1,2,[5,6,7])#([5, 6, 7],)
add(1,2,*[5,6,7])#(5, 6, 7)
def add(a,b=2,*c,**d):
    print(c,d)
add(1,2,*[5,6,7],id='001')#(5, 6, 7) {'id': '001'}
add(1,2,*[5,6,7],**{'id':'001','price':'95'})#(5, 6, 7) {'id': '001', 'price': '95'}
  1. lambda
s=[1,2,3,4]
def add(i):
    return i+2
s2=map(add,s)
print(list(s2))#[3, 4, 5, 6]

s2=map(lambda i:i+2,s)
print(list(s2))#[3, 4, 5, 6]
from functools import reduce
s=[1,2,3,4]
s2=reduce(lambda x,y:x*y,list(range(1,6)))
print(s2)
  1. Python中global和nonlocal的区别
    global:在函数或其他局部作用域中使用全局变量
    nonlocal:在函数或其他作用域中使用外层(非全局)变量
a=1
def add(x):
    global a
    a=a+1
    global c#局部变量全局化
    c=2
    return x+a
print(add(2))#4
print(c)#2
a=1
def add(x):
    a=2
    def sub():
        global a
        a=a+x
        return a
    return sub()
print(add(200))#201

a=1
def add(x):
    a=2
    def sub():
        nonlocal a
        a=a+x
        return a
    return sub()
print(add(200))#202
  1. 查询和替换一个文本字符串
    replace(替换成的字符串,要被替换的字符串,最多替换次数)
a = 'aaabbbccc'
b = a.replace('b','d',3)
print(b) #aaadddccc

re.sub(正则表达式,替换成的字符串,原字符串,替换次数)

import re
s1 = 'aaabbbccc'
print(re.sub(r'b','d',s1,count=1)) #输出:aaadbbccc
#或者
import re
s2 = 'aaabbbccc'
reg = re.compile(r'b')
print(reg.sub('d',s2,count=4))#输出:aaadddccc
  1. match()和search()的区别
  • match()从字符串的开始匹配,匹配不成功返回None
  • search()在字符串内匹配,只找到第一个匹配并返回,匹配不成功返回None
  1. __new__() 与__init__()的区别
    __new__作用于__init__()之前
    __init__ 是实例级别的方法,通常用于初始化一个新实例。
    __new__是类级别的方法,通常用于控制生成一个新实例的过程。
  2. 列举几种设计模式
    工厂方法模式:定义一个创建对象接口,通过子类来创建对象。
    单例模式:一个类仅有一个实例,例如框架中的数据库连接
  3. 闭包
    内函数里运用了外函数的临时变量,并且外函数的返回值是内函数的引用
def a(s):
    def b(s):
        print(s)
    return b(s)
a('123')
  1. 回调
    把函数作为参数传递给另一个函数
def a(s):
    print(s)
def b(func):
    func('123')
b(a)
  1. Python字符串的编码与解码
    decode将其他编码转unicode编码
    encode将unicode编码转其他编码
s1='abc'
s2=s1.encode('utf-8') #utf-8编码转unicode编码
print(s2) #输出:b'abc'
s1=s2.decode('utf-8') #unicode编码转utf-8编码
print(s1)#输出:abc
  1. 装饰器的作用
    在不改变函数本身的情况下,为函数增加新的功能
  2. 列举HTTP请求中的状态码
    200 访问成功
    302 重定向
    404 请求的url不存在
    500 服务器端错误
    505 HTTP版本不受支持
  3. Flask蓝图的作用
    使不同的功能模块化
    优化项目结构
    增强可读性,易于维护
  4. Python生成随机数
  • Python生成随机数
    random.randrange(起始位置,结束位置,步长)
import random
print(random.randrange(10))
print(random.randrange(100,200))
print(random.randrange(300,400,50))
  • 在一个范围内,生成不重复的随机数
    s=random.sample(范围,生成数量)
import random
print(random.sample(range(0,5),3))
print(random.sample([1,2,3,4,5],3))
  1. import 和 from import的区别
    import 导入整个模块,每次使用模块中的函数时需要确定是哪个模块
    from import 创建 一个副本,导入模块中的函数,可以直接使用
  2. Python解释器对模块位置的搜索顺序
    当前主目录、PYTHONPATH下的每个目录、标准第三方链接库、.pth文件
  3. 静态方法和类方法的关键字
    静态方法: @staticmethod
    类方法:@classmethod
  4. Python主要特点和优点
    可解释
    具有动态特性
    面向对象
    简明简单
    开源
    具有强大的社区支持
  5. Python的自省
    运行时能够获得对象的类型。
    如:type() dir() getattr() hasattr() isinstance()
  6. Python中的但双下划线
    单下划线用处:解释器中、名称、i18n
    单下划线前缀的名称:受保护的,仅能内部访问
    双下划线前缀的名称:私有的,仅类对象自己能访问(子类也不能访问)
    双下划线开头加结尾:Python系统自带的一些函数和方法
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,820评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,648评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,324评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,714评论 1 297
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,724评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,328评论 1 310
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,897评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,804评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,345评论 1 318
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,431评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,561评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,238评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,928评论 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,417评论 0 24
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,528评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,983评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,573评论 2 359

推荐阅读更多精彩内容

  • 一、快捷键 ctr+b 执行ctr+/ 单行注释ctr+c ...
    o_8319阅读 5,828评论 2 16
  • 〇、前言 本文共108张图,流量党请慎重! 历时1个半月,我把自己学习Python基础知识的框架详细梳理了一遍。 ...
    Raxxie阅读 18,966评论 17 410
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,111评论 1 32
  • 师祖将手中莲花放入身前的燋盆中,牵着猫耳步入厅内。闻溪正襟端坐,合手扶在丹田,看来刚才这一番恶斗,真气已经大乱,稍...
    长楼阅读 327评论 0 0
  • 今天的打卡内容,对我的帮助超级无敌大!与我的工作身份,十分的相符!感谢宇彤老师的练习题目!感谢老师眷顾!
    小炸弹阅读 180评论 0 1