在线时间 1630 小时 最后登录 2024-1-29 注册时间 2017-5-16 听众数 82 收听数 1 能力 120 分 体力 563327 点 威望 12 点 阅读权限 255 积分 174221 相册 1 日志 0 记录 0 帖子 5313 主题 5273 精华 3 分享 0 好友 163
TA的每日心情 开心 2021-8-11 17:59
签到天数: 17 天
[LV.4]偶尔看看III
网络挑战赛参赛者
网络挑战赛参赛者
自我介绍 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
群组 : 2018美赛大象算法课程
群组 : 2018美赛护航培训课程
群组 : 2019年 数学中国站长建
群组 : 2019年数据分析师课程
群组 : 2018年大象老师国赛优
全网最全Python项目体系练习500例(附源代码),练完可就业
* [; d$ S" i2 E9 ^2 D2 Q% p9 u
% C7 J) D! a$ U7 u* ?5 o4 {& Z/ I- h 1.有一个jsonline格式的文件file.txt大小约为10K " G( H' V6 m2 K, Z% c, V9 `& x& }
2.补充缺失的代码 5 ~' I0 @% o' z, v; S1 e# @: ?
3.输入日期, 判断这一天是这一年的第几天?
2 @+ A( s( [: b# W/ I 4.打乱一个排好序的list对象alist?
! G; F" y7 x9 d* ?" o7 ~ 5.现有字典 d= {‘a’:24,‘g’:52,‘i’:12,‘k’:33}请按value值进行排序?
F* _1 s5 l5 k* O2 I$ k) R& [/ v 6.字典推导式 % [: ~& h" U6 e$ u+ L i7 d! E' m! P3 C) m
7.请反转字符串 “aStr”?
6 }6 p6 v7 S1 `' l/ S8 Y 8.将字符串 “k:1 |k1:2|k2:3|k3:4”,处理成字典 {k:1,k1:2,…}
% B; A3 T# N( o9 V7 v8 i 9.请按alist中元素的age由大到小排序 ' G& r: o$ W! `. Z: f+ s9 N2 `5 U7 J) `
10.下面代码的输出结果将是什么? & a% h7 X; v) I# n) s- U4 C
11.写一个列表生成式,产生一个公差为11的等差数列 + N; ^2 F9 B& Y5 h
12.给定两个列表,怎么找出他们相同的元素和不同的元素?
% l h; m0 V2 x 13.请写出一段python代码实现删除list里面的重复元素?
8 n8 Y" S8 A0 m: [ 14.给定两个list A,B ,请用找出A,B中相同与不同的元素 企业面试题 , w$ }* T3 E" _ T2 S# p7 i \ }! [
15.python新式类和经典类的区别?
) d; S) L1 v d5 n 16.python中内置的数据结构有几种?
% k% a4 p) q) b* }8 R; K: K8 H 17.python如何实现单例模式?请写出两种实现方式?
3 c) z# m* b) c% [) u. T 18.反转一个整数,例如-123 --> -321
" i) i3 Y% D! T; P2 p" x 19.设计实现遍历目录与子目录,抓取.pyc文件
$ n7 y/ t( w: W) _; K8 E, z 20.一行代码实现1-100之和 " f6 t; n {* I5 f6 z; U( N
21.Python-遍历列表时删除元素的正确做法 ' p$ O8 }4 g- N
22.字符串的操作题目
, n3 l5 V& g ?* d0 C9 _ 23.可变类型和不可变类型 ' f0 g+ }8 ^5 R! ?. F! y
24.is和==有什么区别?
* e0 g, _9 q! e, x+ M 25.求出列表所有奇数并构造新列表 2 P1 {* w h, k- w/ |2 {. d& [" ]
26.用一行python代码写出1+2+3+10248 . c* t: ^5 ~& R. |* V
27.Python中变量的作用域?(变量查找顺序)
: q+ d: U/ _9 R' B' @: { 28.字符串 “123” 转换成 123 ,不使用内置api,例如 int() . o3 k$ r! c; m9 g" w
29.Given an array of integers
6 U0 V4 Z( `7 o. \ ]9 @$ e2 _ 30.python代码实现删除一个list里面的重复元素
' q' E$ i# n m 31.统计一个文本中单词频次最高的10个单词? 2 t4 t& S9 ^. D
32.请写出一个函数满足以下条件
) u1 E3 ]3 Q$ \ 33.使用单一的列表生成式来产生一个新的列表 8 `$ J: U" c- ~& a$ l+ | k
34.用一行代码生成[1,4,9,16,25,36,49,64,81,100] ) ?8 N- i# y0 M* r
35.输入某年某月某日,判断这一天是这一年的第几天? / f* v! M7 A0 a- H5 t5 A6 q, |: i# H
36.两个有序列表,l1,l2,对这两个列表进行合并不可使用extend
6 n' W. I7 f$ O8 G 37.给定一个任意长度数组,实现一个函数 3 D V, X" O8 C# K
38.写一个函数找出一个整数数组中,第二大的数 ' m1 F8 `% b* r. R d
39.阅读一下代码他们的输出结果是什么? 3 n& u4 [% r! g- t( }+ y7 N
40.统计一段字符串中字符出现的次数
6 F: z: B% U. K1 e j* a8 ~& h 41.super函数的具体用法和场景
0 |. f: p f8 E4 U1 Q$ ^ 42.Python中类方法、类实例方法、静态方法有何区别?
/ s# y9 F2 r H, F, y9 }* j7 | 43.遍历一个object的所有属性,并print每一个属性名? : Q T# ?8 E; @6 s; v' E" V/ h: L8 x
44.写一个类,并让它尽可能多的支持操作符?
8 X1 _$ w' g% b9 \4 [ 45.介绍Cython,Pypy Cpython Numba各有什么缺点
" Z8 S7 M/ n' Q. q( ` 46.请描述抽象类和接口类的区别和联系 : p3 Z# I' k. O! L3 m. F: K! y
47.Python中如何动态获取和设置对象的属性? 5 {; d8 r" U' I2 I1 r* Y% D
48.哪些操作会导致Python内存溢出,怎么处理?
0 E+ Y. o! X" i# i3 F# w' k 49.关于Python内存管理,下列说法错误的是 B
9 h( v- t4 @: ~0 D 50.Python的内存管理机制及调优手段?
7 r$ H$ w X+ A' Q 51.内存泄露是什么?如何避免?
- d X6 R9 y5 B) e1 h) Y6 h 52.python常见的列表推导式? 7 d5 t, [/ F* u
53.简述read、readline、readlines的区别?
8 T" o' n& ^7 p9 V: `; X; Y 54.什么是Hash(散列函数)? ) |7 y6 \( N) w1 J2 F
55.python函数重载机制? 2 A% F& d& ?/ p+ B; m4 j! ?3 r! \
56.写一个函数找出一个整数数组中,第二大的数 4 |2 o9 M% B' D$ S. u: b% f
57.手写一个判断时间的装饰器 1 r9 c# O# V7 B* e
58.使用Python内置的filter()方法来过滤?
( K! Q4 i0 n9 W 59.编写函数的4个原则
* v, o. _+ G5 H0 E( }1 K3 O8 w 60.函数调用参数的传递方式是值传递还是引用传递? , E* i4 L- m7 p7 m4 K
61.如何在function里面设置一个全局变量 9 o/ c( i8 d+ `' H1 n8 k
62.对缺省参数的理解 ? - ?( V- K/ `/ B2 d5 y, K
63.Mysql怎么限制IP访问?
( o$ }2 N6 @8 @0 O/ Y 64.带参数的装饰器?
+ {5 a; M: Z0 J 65.为什么函数名字可以当做参数用?
5 o1 ~" s' Y* D* |9 I 66.Python中pass语句的作用是什么?
$ }/ [. K( s( l. } 67.有这样一段代码,print c会输出什么,为什么?
2 D9 I& ?+ J; i1 C 68.交换两个变量的值?
/ g0 k7 l9 {9 s 69.map函数和reduce函数? 7 F- J& N, P9 f) p, w% C
70.回调函数,如何通信的?
0 O; J# ]3 q, A- R 71.Python主要的内置数据类型都有哪些? print dir( ‘a ’) 的输出?
3 L& H) Z0 Z8 X; Q 72.map(lambda x:xx,[y for y in range(3)])的输出? ; F* S8 O& a- @
73.hasattr() getattr() setattr() 函数使用详解?
) y5 R* `8 u: V0 x& s( s- Q 74.一句话解决阶乘函数? % o4 i+ _+ Q# A0 M3 C- r
75.什么是lambda函数? 有什么好处?
6 l2 P( j0 O V) ^1 ], g3 ? 76.递归函数停止的条件?
. j& X( G% |- W$ L 77.下面这段代码的输出结果将是什么?请解释。
0 q# D0 W1 ^$ u/ n4 f 78.什么是lambda函数?它有什么好处?写一个匿名函数求两个数的和 N4 K. ?, F, S& z: ^$ b
79.对设计模式的理解,简述你了解的设计模式?
& R" A5 h3 ^: v* i: b 80.请手写一个单例 & s# s6 s; A. R; s5 I9 t: x
81.单例模式的应用场景有那些? . T) S! j: r5 ~( _# V* F/ f: g
82.用一行代码生成[1,4,9,16,25,36,49,64,81,100]
0 Q7 F( [$ Z( H; X9 | 83.对装饰器的理解,并写出一个计时器记录方法执行性能的装饰器? " _) W' t# T8 B1 W
84.解释以下什么是闭包?
7 i. E) O! A( g. {) Y 85.函数装饰器有什么作用?
1 ~, q ^6 f( a8 H2 ] 86.生成器,迭代器的区别? ! N0 w e) w( K/ R6 }
87.X是什么类型? ' V( Q7 v! V7 ^) H- {* n
88.请用一行代码 实现将1-N 的整数列表以3为单位分组
$ {0 Z( v$ \; Q. W8 n- |9 O5 d2 a 89.Python中yield的用法?
6 H9 O2 x' l& y8 \; w' W 90.Python中的可变对象和不可变对象? 1 c. a; A1 T* y6 B! O3 J
91.Python的魔法方法 3 _& h% P" w- i- b
92.面向对象中怎么实现只读属性? 3 L& t- j. l0 S8 ~0 H
93.谈谈你对面向对象的理解? ; v6 X I1 l) @5 n+ L, r
94.请写出一段代码用正则匹配出ip? - t* ?3 S/ Q7 q5 o: ^% H
95.a = “abbbccc”,用正则匹配为abccc,不管有多少b,就出现一次? / @! W# e% L d5 B* j
96.Python字符串查找和替换? ( `+ E9 [& G& t( A$ j4 K4 L
97.用Python匹配HTML g tag的时候,<.> 和 <.*?> 有什么区别
. ~; j* q( w! s Q( \8 o6 P$ H 98.正则表达式贪婪与非贪婪模式的区别?
" `# y$ E( n' X" @1 H+ x( s 99.写出开头匹配字母和下划线,末尾是数字的正则表达式?
$ D# S" E: G1 P: d" Y/ N8 l 100.正则表达式操作
5 G3 S% C; |* c4 d( U8 G$ s 101.请匹配出变量A 中的json字符串。
' k4 e2 V! Q b9 H3 Y 102.怎么过滤评论中的表情?
# J& ~, E' @& x: c, l' U" h# j% B 103.简述Python里面search和match的区别 - y; o. n2 \% o7 I6 u) ~* I
104.请写出匹配ip的Python正则表达式
) S2 V' T1 l& P3 k* L 105.Python里match与search的区别? % L, {# y3 A+ d+ u( C# B
106.进程总结
/ r# O3 e8 m) g- p' X; Q 107.谈谈你对多进程,多线程,以及协程的理解,项目是否用?
. E% K+ l& A1 [5 K 108.Python异常使用场景有那些? 4 D/ t3 ]3 U# N; w* ~' @
109.多线程共同操作同一个数据互斥锁同步? " `4 k1 d! A! k7 `1 d$ n
110.什么是多线程竞争? 2 ~. @7 |. Y0 @- g- D+ ~' J6 d# m
111.请介绍一下Python的线程同步?
& r0 ~ i/ v* f* P3 H 112.解释以下什么是锁,有哪几种锁?
; g7 w! C+ s) s# s+ Z 113.什么是死锁?
9 q+ M/ Y, M& b+ l4 B3 k 114.多线程交互访问数据,如果访问到了就不访问了? * `1 p; p5 z. e+ R
115.什么是线程安全,什么是互斥锁?
$ N6 {2 Z. p) z! c; Q 116.说说下面几个概念:同步,异步,阻塞,非阻塞?
: o- B4 z4 ]9 q: w 117.什么是僵尸进程和孤儿进程?怎么避免僵尸进程? 7 m7 }! `" Y |
118.python中进程与线程的使用场景?
7 [ P W3 I% Z) @ 119.线程是并发还是并行,进程是并发还是并行?
: v; O" E4 @ J' G5 d 120.并行(parallel)和并发(concurrency)? 8 r! [* s" W* x4 _2 ~3 G
121.IO密集型和CPU密集型区别? / X3 \: N6 I4 I# u k- H8 M
122.python asyncio的原理? " K4 G2 y# L. D/ y I1 a/ g9 E+ @
123.怎么实现强行关闭客户端和服务器之间的连接? ( ~! x% Q7 Z1 L" S0 g% i/ U
124.简述TCP和UDP的区别以及优缺点?
% X) ~2 V- p3 N; u' w: l6 k 125.简述浏览器通过WSGI请求动态资源的过程?
, y5 m: i9 }) q. c2 A 126.描述用浏览器访问www.baidu.com的过程
) G8 _/ C/ z' l7 B2 X8 C( p6 ~ 127.Post和Get请求的区别?
- U6 y$ ~" s# T% h. V, s, m 128.cookie 和session 的区别? . r; T6 l& }3 E5 I' [# `
129.列出你知道的HTTP协议的状态码,说出表示什么意思?
% a/ {6 h$ l& c* t2 E 130.请简单说一下三次握手和四次挥手?
3 v9 t1 |/ ]8 ^: e2 X 131.说一下什么是tcp的2MSL? 2 S4 K7 i" S: s/ i# p. ~& h' O: W
132.为什么客户端在TIME-WAIT状态必须等待2MSL的时间?
3 j# W: I$ e' M, k$ Y" f 133.说说HTTP和HTTPS区别? ' T! x6 e. d5 A- |8 G
134.谈一下HTTP协议以及协议头部中表示数据类型的字段? : _9 E* h+ y+ i1 I# ?% E$ d
135.HTTP请求方法都有什么?
: u5 A' d) G7 t$ V$ B* q 136.使用Socket套接字需要传入哪些参数 ?
; E! F& K; Z& S$ H4 \# h! k6 {8 B 137.HTTP常见请求头?
' D# t. ~0 ?, K9 g* j 138.七层模型?
- L- p7 n- @1 o Q( N( S; p 139.url的形式?
) n3 K: s( j/ |. L. H1 E @. K8 e 140.对Flask蓝图(Blueprint)的理解? $ j7 ~% ]! _- e3 U- b& @
141.Flask 和 Django 路由映射的区别? - x0 k2 v+ y; P( D+ }5 A
142.什么是wsgi,uwsgi,uWSGI? / w1 y2 y* l1 [; y
143.Django、Flask、Tornado的对比? ; t0 x3 |9 U0 k- o4 L+ K
144.CORS 和 CSRF的区别?
* B0 y [9 T3 r0 m1 h% @, H) I 145.Session,Cookie,JWT的理解
7 i+ Y! K7 a) g' I/ I 146.简述Django请求生命周期
6 y; W) t& e. V( o( B* F+ l* Q0 u 147.用的restframework完成api发送时间时区
5 g6 `- v7 y E 148.nginx,tomcat,apach到都是什么? 0 k1 B$ C/ q$ Y2 ^5 D
149.请给出你熟悉关系数据库范式有哪些,有什么作用?
9 W5 x/ z( O, y" ^6 e1 R 150.简述QQ登陆过程 # v7 b: {" @, o' G9 H
151.post 和 get的区别? 4 r7 d, l- Z% W/ a: r
152.项目中日志的作用
4 W: Z, ~3 r# M7 m0 v# v( [ 153.django中间件的使用? * @4 `+ y; u( k5 }2 |5 c
154.谈一下你对uWSGI和nginx的理解?
$ q/ d3 t; U" D) ?5 Q 155.Python中三大框架各自的应用场景?
" D8 Q4 k3 j: u/ N: v, L 156.Django中哪里用到了线程?哪里用到了协程?哪里用到了进程? 8 G. B* e' N, J, g( A8 z ^
157.有用过Django REST framework吗?
- P9 z4 N0 S6 k' _3 p$ P* v0 v 158.对cookies与session的了解?他们能单独用吗?
' X3 }: K1 Z) u+ Q. V2 ? 159.试列出至少三种目前流行的大型数据库
1 f8 s! h1 g0 Q+ C3 }# j 160.列举您使用过的Python网络爬虫所用到的网络数据包?
& K2 b2 u0 `. ~ 161.爬取数据后使用 " Y; c& b9 y& z# r9 U$ {+ o
哪个数据库存储数据的,为什么? 162.你用过的爬虫框架或者模块有哪些?优缺点?
+ b$ r5 ]) M6 n# ?( @ 163.写爬虫是用多进程好?还是多线程好? 8 h3 E" r4 o' \
164.常见的反爬虫和应对方法?
9 S- b; ?( c- m 165.解析网页的解析器使用最多的是哪几个?
Y4 a, r' b2 V0 S* Q, ~ 166.需要登录的网页,如何解决同时限制ip,cookie,session : f/ ?" I& q, p* R: q: L
167.验证码的解决? / f7 d# [0 }, a4 ?6 J [
168.使用最多的数据库,对他们的理解? " J! Q! q) s" [" D" R
169.
* [4 T3 z7 }" ]) Z 编写过哪些爬虫中间件? 170.“极验”滑动验证码如何破解? / ^ @& E) d4 s! |) _1 q
171.爬虫多久爬一次,爬下来的数据是怎么存储? I. X9 F2 W$ M% M: y& N. }
172.cookie过期的处理问题?
* j4 A+ d# p4 l1 L4 J7 c 173.动态加载又对及时性要求很高怎么处理?
7 H2 f& ^: @, c3 T 174.HTTPS有什么优点和缺点? / j+ {" L7 A9 S# J* i- Z
175.HTTPS是如何实现安全传输数据的? ; V4 b5 E4 H" Y/ ]- m- F4 B4 S2 ]4 N
176.TTL,MSL,RTT各是什么?
% J" n* U- l, H8 l 177.谈一谈你对Selenium和PhantomJS了解
9 R) |0 _% u& ~1 R 178.平常怎么使用代理的 ? 5 {6 A$ t s1 x2 G3 {1 S. O
179.存放在数据库(redis、mysql等)。 / J; v4 r9 n3 ?0 u" O7 y9 L
180.怎么监控爬虫的状态?
# A: g$ z) k7 O' K 181.描述下scrapy框架运行的机制?
! p3 N/ d' ~- M9 Y; M, x( ^% t 182.谈谈你对Scrapy的理解?
* l! A) q! t0 R9 L; i# z 183.怎么样让 scrapy 框架发送一个 post 请求(具体写出来) : |+ M2 Q5 d& q. b1 m
184.怎么监控爬虫的状态 ? ( C% O2 a* F$ E0 x9 w
185.怎么判断网站是否更新?
( X+ \! ]* o7 H; W 186.图片、视频爬取怎么绕过防盗连接
- }9 d a* ^# ?) \) R3 G* y 187.你爬出来的数据量大概有多大?大概多长时间爬一次? / H. ^9 n( f1 z6 Y: A* \( d4 i e" e
188.用什么数据库存爬下来的数据?部署是你做的吗?怎么部署?
' S. f* w0 ]1 Y$ y 189.增量爬取 ) j8 ]# P! a! [& Z1 J
190.爬取下来的数据如何去重,说一下scrapy的具体的算法依据。 5 e e; R C3 o8 V. V, S3 Q
191.Scrapy的优缺点? * u/ `8 n5 r% B
192.怎么设置爬取深度?
) y! _" S. V5 l 193.scrapy和scrapy-redis有什么区别?为什么选择redis数据库?
$ M( t; A9 S: ` q: j2 w9 ?9 d 194.分布式爬虫主要解决什么问题?
" `$ `) L. @2 C( A' O- [6 S 195.什么是分布式存储?
9 j; ^- u4 c5 d" W 196.你所知道的分布式爬虫方案有哪些?
1 K: [# P& j" U" B* @# h0 E 197.scrapy-redis,有做过其他的分布式爬虫吗? ! i* S; S7 ]# N% Y x9 U; [
198.主键 超键 候选键 外键 # y. B4 W! Y+ D7 i
199.视图的作用,视图可以更改么? - Y+ C0 M3 e: `$ |1 z' v4 }, V
200.drop,delete与truncate的区别 ! W- W4 a2 W9 s; [
201.索引的工作原理及其种类 0 l" a$ T- P( E" C
202.连接的种类 - I& }" p- ]3 [
203.数据库优化的思路 ; A. F* c# ], |6 H
204.存储过程与触发器的区别 " H9 Y; f6 T' h( { ~. M( q
205.悲观锁和乐观锁是什么?
3 @" d8 L9 o6 C4 ^8 D: T4 F 206.你常用的mysql引擎有哪些?各引擎间有什么区别? - \: G3 Q" F7 r2 ]
207.Redis宕机怎么解决?
7 \* v7 y3 N; { 208.redis和mecached的区别,以及使用场景
6 V& @9 B: @6 ?+ T1 u 209.Redis集群方案该怎么做?都有哪些方案? 5 x7 ~6 |# L$ }. m, p
210.Redis回收进程是如何工作的 ! n: A, R8 e% b* x( _( q6 T1 g
211.MongoDB中对多条记录做更新操作命令是什么?
9 x/ X. Z: x" B& |% f8 w8 \ 212.MongoDB如何才会拓展到多个shard里?
$ {) L$ ^. w2 a# P 213.编写测试计划的目的是
( W& O9 X9 y+ {9 Z7 ]1 U9 z 214.对关键词触发模块进行测试 % z5 d% i' W% u9 \8 w! a) J
215.其他常用笔试题目网址汇总
# t" G1 a2 P: z9 x 216.测试人员在软件开发过程中的任务是什么 0 c) F- q( k( Z5 r
217.一条软件Bug记录都包含了哪些内容? - ?; a. A& ~. o& z' _
218.简述黑盒测试和白盒测试的优缺点 0 {1 M6 p4 T+ D H: U* z- B J
219.请列出你所知道的软件测试种类,至少5项 ' H- Q$ p$ d; h |0 R2 K" T; R
220.Alpha测试与Beta测试的区别是什么? . E p# w9 K5 `4 W" {+ ^
221.举例说明什么是Bug?一个bug report应包含什么关键字? . B) `* u. R+ S$ U R) w, ^
222.数组中出现次数超过一半的数字-Python版 / m2 _: L: G3 }& k
223.求100以内的质数 $ U$ E1 t5 @ Q4 ^; n
224.无重复字符的最长子串-Python实现
# x. ^' t: ?4 C8 G 225.通过2个5/6升得水壶从池塘得到3升水 . m/ Y) n( V: U) ?: {4 n0 t
226.什么是MD5加密,有什么特点? / a6 A7 p0 z# N! ?/ j
227.什么是对称加密和非对称加密 & f2 K6 J" @* C$ C9 m# N
228.冒泡排序的思想?
, a9 b$ r, ~0 v8 ~. h- m& ~ 229.快速排序的思想? 1 g8 m. ^3 V$ S+ Z
230.如何判断单向链表中是否有环? ( v3 C5 n* V: Q, Z! X: K2 a
231.你知道哪些排序算法(一般是通过问题考算法)
# y J) x6 e' Q" J 232.斐波那契数列 6 Y6 O0 `3 a) d( V2 I" L4 K' \
233.如何翻转一个单链表?
1 L) Q, D! J" {' }- R 234.青蛙跳台阶问题
& _5 N: q0 ^( [' D$ _% ]7 V 235.两数之和 Two Sum
. X* [$ V) W- ?- j; i 236.搜索旋转排序数组 Search in Rotated Sorted Array
: [% S" |3 Y2 L+ A8 v 237.Python实现一个Stack的数据结构
+ m. j" b6 I: \2 c8 c$ {% d 238.写一个二分查找 8 n( p/ M+ ]4 b5 _6 v1 B1 t
239.set 用 in 时间复杂度是多少,为什么? 7 a/ ~8 i3 C+ a2 [6 R
240.列表中有n个正整数范围在[0,1000],进行排序;
; B( c8 P$ m; d$ ~' g% ] 241.面向对象编程中有组合和继承的方法实现新的类 ) n! x$ X# X- |# R
242.找出1G的文件中高频词 $ O: Q' ~% H# W0 W
243.一个大约有一万行的文本文件统计高频词
" @: N0 F O' E3 y: A$ r0 b! P 244.怎么在海量数据中找出重复次数最多的一个?
$ I- n7 Z4 d. f 245.判断数据是否在大量数据中 8 n( Q2 y. ], d9 a+ M1 W: S+ x
51.内存泄露是什么?如何避免?
+ Z# L3 ^0 Y& ?6 i- f
1 R9 v. @* S0 m! }
* O% a$ L; s! T9 r { 内存泄漏指由于疏忽或错误造成程序未能释放已经不再使用的内存。内存泄漏并非指内存在物理上的消失,而是应用程序分配某段内存后,由于设计错误,导致在释放该段内存之前就失去了对该段内存的控制,从而造成了内存的浪费。
+ z" X- n) o# j! c6 F; Y! y2 g+ q3 g! d
4 M3 X0 J! ^! A1 w
& a$ [: G% S, M2 l) C0 y7 J 有 del() 函数的对象间的循环引用是导致内存泄露的主凶。不使用一个对象时使用: del object 来删除一个对象的引用计数就可以有效防止内存泄露问题。 & L/ h% {6 i% }! d6 a. }2 ]
* B' O. z2 a$ h# P/ L' q 5 N) @6 Q/ [# L: e2 o$ P7 e
通过Python扩展模块gc 来查看不能回收的对象的详细信息。 # U8 S, D, D4 n$ w* z. [
2 Y+ o# u8 _) |
: O" q% ^2 B1 J5 k/ h 可以通过 sys.getrefcount(obj) 来获取对象的引用计数,并根据返回值是否为0来判断是否内存泄露 ! }% v |0 S' L
, L$ ^# l3 R+ a
8 h' G0 E. Y& u' C+ `" | 52.python常见的列表推导式?
8 j4 U/ f" q2 E: g2 S % V c: M" P# h, K) I3 e! z% C
" U4 K; Z* a! G0 ]5 d+ B2 y
[表达式 for 变量 in 列表] 或者 [表达式 for 变量 in 列表 if 条件]
7 L, M! ^; O$ O) A% s$ f3 [+ M& } 1
8 n P8 g+ V+ ?4 \% ?# T. @, ~ 53.简述read、readline、readlines的区别? , P0 J% U% L h. A" f% e6 m
5 d* u6 ]5 ]* ^' H" R: Q 2 T! \5 F, I+ ?- N0 U
read 读取整个文件
- d5 q) R: H; k6 p) \3 P, ? readline 读取下一行 : C2 F, h! G- r; s8 E3 O
readlines 读取整个文件到一个迭代器以供我们遍历
, y3 H/ {8 l8 X# ` 9 N1 i; V! I! Q0 T3 \: q4 o( l9 s
+ F' d- K: }$ m1 o4 @2 T+ Y. @ 54.什么是Hash(散列函数)? ! r6 E. O5 I4 y& M* }' {8 R/ v
! L2 \; N& p8 C. s # Q2 v- m! q* u0 @1 ~* P# b
散列函数(英语:Hash function)又称散列算法、哈希函数,是一种从任何一种数据中创建小的数字“指纹”的方法。散列函数把消息或数据压缩成摘要,使得数据量变小,将数据的格式固定下来。该函数将数据打乱混合,重新创建一个叫做散列值(hash values,hash codes,hash sums,或hashes)的指纹。散列值通常用一个短的随机字母和数字组成的字符串来代表 ; r$ z2 e5 p# }% C: G4 {7 H
% J& b3 C! J& y! d# _, o* H 1 U; v1 K; x X S: i
55.python函数重载机制?
! u& o* I# H1 B @
7 j2 {# L/ A4 Z 3 P1 x/ L- s& ^+ R
函数重载主要是为了解决两个问题。 5 S1 o# s. y+ g, z8 v/ W
1。可变参数类型。 6 y# X& y9 K) `1 b4 k$ [
2。可变参数个数。
3 m; D( y; v6 y0 l/ n/ _/ R 7 J+ X# Q1 C" }' E- m, K B- b
% ^! J7 j1 Y7 g8 x( s6 A% O
另外,一个基本的设计原则是,仅仅当两个函数除了参数类型和参数个数不同以外,其功能是完全相同的,此时才使用函数重载,如果两个函数的功能其实不同,那么不应当使用重载,而应当使用一个名字不同的函数。 ) g- w& m# x9 @, \1 W7 \- ^
! }2 d |: P/ g ( k/ [8 O" W. K3 ?1 ~% {6 n; H
好吧,那么对于情况 1 ,函数功能相同,但是参数类型不同,python 如何处理?答案是根本不需要处理,因为 python 可以接受任何类型的参数,如果函数的功能相同,那么不同的参数类型在 python 中很可能是相同的代码,没有必要做成两个不同函数。 . a, \# |9 ~$ r6 O0 Q/ x
. p2 |- c8 [) f' u, E$ W3 \
! z& {8 x1 w) C* `& i' K* W 那么对于情况 2 ,函数功能相同,但参数个数不同,python 如何处理?大家知道,答案就是缺省参数。对那些缺少的参数设定为缺省参数即可解决问题。因为你假设函数功能相同,那么那些缺少的参数终归是需要用的。 9 \2 j! l. w; _ D7 u- P) n
. b- W4 t2 v* d1 X/ _ " n* s- w: E- G, D- A3 Z
好了,鉴于情况 1 跟 情况 2 都有了解决方案,python 自然就不需要函数重载了。 % ~5 C6 e5 L# [. e+ \+ ?
: y+ @2 C1 x5 u" P1 U
% ~1 z: @* _9 c1 A- W7 @: v 56.写一个函数找出一个整数数组中,第二大的数
% ?2 |& ~( [2 n4 j r0 ~9 V2 o $ b* H+ J7 w- c. d# R
8 K% @2 U: X) Q0 v; _$ F! | 57.手写一个判断时间的装饰器
/ |3 }' `! {7 q- { 7 T* F- B" P8 ?3 j/ A2 l
' n1 i# b5 x5 m+ }6 e6 x6 \
' ~: n8 B+ d k# [5 W; Y
% _! T- v/ k1 X! Y: R
58.使用Python内置的filter()方法来过滤?
: h# k0 |3 L" Y1 E+ r * M4 o5 U) g6 c6 k& O3 U9 U
* O" I: v( E8 E! j
list(filter(lambda x: x % 2 == 0, range(10)))
- E- N& G5 ?6 p/ u+ s0 k- O 1 4 K, J7 K3 j) z8 O
59.编写函数的4个原则
% }, m3 s, s% O4 T& y; o+ E0 e& b- U & Z2 k- g/ I& N" q. ]" d* Y
+ s- Y0 |9 P+ ?% J+ G) ? 1.函数设计要尽量短小
4 j( }. L% R, g5 J8 \
* d1 m j4 a9 F$ S6 b* O6 Y- i ) E/ \+ X- H6 g: ^- Y
2.函数声明要做到合理、简单、易于使用
& K5 S, \% c0 ]; \( v _
# q) K& x- Z8 r0 Z
0 }( M: D2 Q2 Z5 K7 |6 F( H; K 3.函数参数设计应该考虑向下兼容 & b; w# O+ g1 ?
! T) K2 Q; ^9 H- Q9 S* T6 _ v - N- z! ~6 J! [
4.一个函数只做一件事情,尽量保证函数语句粒度的一致性
7 m% b- \) I% k ( {# c+ u9 U4 Z
* O8 r" T! u F) ` G 60.函数调用参数的传递方式是值传递还是引用传递?
5 k4 F% L2 L) P: b4 M5 l
2 b: O9 l( N# o 8 l, M% I- Q# B
Python的参数传递有:位置参数、默认参数、可变参数、关键字参数。
8 Z2 e# z7 R3 ^7 l( ]$ k; E- z9 n 函数的传值到底是值传递还是引用传递、要分情况: 5 z: m: ?0 m( G) F$ O$ F
) t# y1 ?' g) ^6 r* E" X
8 |1 r) t! U6 I; W! m9 E6 t! V! D 不可变参数用值传递:像整数和字符串这样的不可变对象,是通过拷贝进行传递的,因为你无论如何都不可能在原处改变不可变对象。
3 E& Z9 _. f4 z+ Q% n 可变参数是引用传递:比如像列表,字典这样的对象是通过引用传递、和C语言里面的用指针传递数组很相似,可变对象能在函数内部改变。 ) Y" E. b7 V6 o2 F' V' G
+ [( p i' O0 d9 K8 K
- [) Q5 e9 U) g0 J! n 61.如何在function里面设置一个全局变量 & B0 e/ Q0 I. ^9 F2 A& s
+ _7 `, i: \0 o0 Y
2 q+ r7 F1 Q+ I; m2 ^% h
globals() # 返回包含当前作用余全局变量的字典。 7 T( Y. Y. P, ?, k+ a
global 变量 设置使用全局变量 1 X \* p0 u$ F* g7 r: e
1 1 d& I# Y: u6 z8 B
2
+ q; z/ u: k. z 62.对缺省参数的理解 ? ) s# X# _; ?5 U; z" Z8 o
* H& \7 a, p+ U) t5 X) ^
8 Y! V7 ]8 b& U
缺省参数指在调用函数的时候没有传入参数的情况下,调用默认的参数,在调用函数的同时赋值时,所传入的参数会替代默认参数。 0 K( A+ q- f% h
5 |8 \ j8 i5 v2 e
# |2 \) M3 R3 O! ~ *args是不定长参数,它可以表示输入参数是不确定的,可以是任意多个。 # [8 P: |6 \5 o0 d( u& t% K, q9 Q
**kwargs是关键字参数,赋值的时候是以键值对的方式,参数可以是任意多对在定义函数的时候不确定会有多少参数会传入时,就可以使用两个参数 ' o* s0 H5 k" O4 ` E) p
- a) v8 h0 Q y j/ ^; h 2 \( q- Z+ g0 G' e3 s0 i) _
63.Mysql怎么限制IP访问? ' D- E7 H& M1 w% }8 u9 Z; @
( z2 @; C. L* y; J) ]/ U, _% [
: Z X5 o% G0 Y2 {( e3 x 64.带参数的装饰器? % t z: e% I3 }! F# s- \& _5 M6 R1 L& q
带定长参数的装饰器
* o% F% j' c1 a' j5 }. v
6 L2 N! u6 _6 J& ?# q / l: B6 j( Q; x. Y* M
% X- U; S" ]4 i: k2 I
( z7 Z: ?5 ~, t; n. G, _ # n) M9 b" `' X3 `
6 O# r4 m+ g' Q6 S! o4 O* Y& D. g( u 带不定长参数的装饰器 2 P- R2 u' K7 d4 t \
( h! k6 y3 e* x: H+ [
. i* B4 b3 Q; ?
/ s2 ~0 x6 U! ]' q, n9 j 0 K% R' E& @$ _/ o
65.为什么函数名字可以当做参数用? * ^/ ~- q& \5 w! F8 f
: L. s5 ^' g" Z- |2 U# q; T# W
: ]- O3 B; m! `) k: B Python中一切皆对象,函数名是函数在内存中的空间,也是一个对象
! d* m+ v7 I+ O' N( W6 n
' X9 D6 A I7 `/ t8 i. k- ]5 |. y 0 w/ i1 r0 K8 N6 ]( D0 T
66.Python中pass语句的作用是什么?
+ w6 n0 L9 |; A) } V" Z
" h0 y- s2 p0 x
1 a* e7 p- i7 U' a& ] 在编写代码时只写框架思路,具体实现还未编写就可以用pass进行占位,是程序不报错,不会进行任何操作。
! E8 S. u, n w. G4 b* _1 G' A ) g7 Y* w$ K( a% f! O1 B
! P! `# b1 f+ Z; l6 a 67.有这样一段代码,print c会输出什么,为什么?
0 p$ d! b5 Y! W0 Z9 [' P2 {) j : c; \* c0 C7 ]
, s( m W% X% o% B3 \- j3 T! o, c6 x% P
a = 10 * B+ `/ q. d7 O, h
b = 20
1 D& j2 i: `4 d" w [ c = [a]
/ J! l# m% t1 I* {- b- \7 ` a = 15
! E0 u2 O" I4 U& m0 g9 ?! K7 d 1 ' [) b, K% Q2 G! e& O# e
2
' X. Z f" ]" M8 o& m: x- B" G 3
' @7 E0 A, ]( N3 b. P 4 - y8 V) Q1 g2 l6 l. {+ h1 Y! G6 k
答:10对于字符串,数字,传递是相应的值
. T' u9 F% M: x$ J7 O4 Z5 r! o + }4 A, \2 ]: w( V
4 [- h( }+ t1 H 68.交换两个变量的值?
3 m, [4 d# B- v8 M h6 J. I% q
: p" d. e y. y4 r+ ^3 J 4 O. v) x7 Y2 r: r2 H4 @& {, x
a, b = b, a
! ~1 ^' a; K% c2 X* y4 H 1
- c/ U- U+ P% v# Z 69.map函数和reduce函数?
9 G ?* W6 G0 _1 N; A L. B
& O. J; m3 ?2 V. X5 d' | ( o- h# ?3 v+ z1 G+ }. r1 d
0 v1 j6 k5 V, q* U8 \
5 Y+ {7 v n+ { 70.回调函数,如何通信的? * [& O& C$ s, ]0 Q+ x
8 X) c4 V' }8 A4 W
" T6 {7 }" W8 O0 S2 {+ `: T; [( n 回调函数是把函数的指针(地址)作为参数传递给另一个函数,将整个函数当作一个对象,赋值给调用的函数。 + t" T1 ?& M$ Q# q
! K' w( n: {& x( J2 e0 N9 [$ m7 q
6 [0 W7 U! C- v V' m 71.Python主要的内置数据类型都有哪些? print dir( ‘a ’) 的输出?
9 e, X/ |9 F' m) G: Z! C9 R ( z E4 u& \% J8 J# s% q1 u9 G
& u" [5 I5 H2 l1 ~2 C( t 内建类型:布尔类型,数字,字符串,列表,元组,字典,集合 * o7 ^) W P: C" J
输出字符串’a’的内建方法
" c3 T4 q5 E6 S3 A. ]% T
t, \5 B) c. c* }6 y * a3 q4 O1 W- C( T P
72.map(lambda x:xx,[y for y in range(3)])的输出?
" \8 j! c1 ?% X' R- w1 ^# Z# a # r* @4 ^% z: p' }; u; P
! A% X. T7 r8 o( ~9 e* K
[0, 1, 4]
/ r7 a+ s+ q* m 1
# q. L% H; g: n 73.hasattr() getattr() setattr() 函数使用详解?
# z( f* {- S0 }2 s/ R
* S* }6 Y& i6 W2 A0 u
1 }( o' V5 K+ C* _/ Z4 N hasattr(object,name)函数:
8 R. V4 V; Z" h2 V( H: _ 判断一个对象里面是否有name属性或者name方法,返回bool值,有name属性(方法)返回True,否则返回False。
- E8 |' h; w$ M1 E. Y9 o( \ . U- a; J! L! \( k% h( j
$ f( A# g1 S# m. {7 O) k7 C
5 T# k/ v% O L# F# w
8 j( Y6 `# v; R0 H6 t C" S0 ? getattr(object, name[,default])函数:
& L: z4 h9 [$ f& N; j$ @) n& `
# b0 k" L3 V: Y8 ?3 a" F2 B+ ? , i/ z2 [' S& a: }6 Y* O0 r# g
获取对象object的属性或者方法,如果存在则打印出来,如果不存在,打印默认值,默认值可选。 $ ^% E3 N, s( ~. ^
- U( a$ } f4 p* C- q- `/ w
0 H* y! J4 B/ | 注意:如果返回的是对象的方法,则打印结果是:方法的内存地址,如果需要运行这个方法,可以在后面添加括号(). 0 ~/ E4 i. g& |- a v
& Z* I$ ?5 d# N% c" j
/ y' b+ L! y4 C/ w8 x: W E# a
; j( M4 e1 i/ l) c, V1 ~
! r/ L0 ? N- s3 @ setattr(object, name, values)函数: ! @! b; ~% P! `/ x/ [" j
( }, O' g' v c. S3 D4 V/ p
" T) N) X1 a" p# O7 Z 给对象的属性赋值,若属性不存在,先创建再赋值 % w& }, q1 r9 M
; F- l: Q" C1 {& P" i
/ K. Z. y2 P$ s0 h& R( @ 8 }4 t D9 ]% }9 z, d' V, X- r
! \7 D% T T* { 综合使用 9 F% {- F% O# J0 j/ r; k
& l/ r5 n/ C3 E. q! l
% R/ B7 B: W9 n+ t0 o1 g
7 b) o! c3 {) y$ z7 j. e
, f- V: w' |0 S7 l3 y" Q/ H, U 74.一句话解决阶乘函数? / e& s# Y: p s( G0 J
$ o" V( c$ N. P q) D
5 M' G: A7 g5 g7 Q9 P3 ?; j3 ^
reduce(lambda x,y : x*y,range(1,n+1)) 6 k$ T# J7 N% G( u
1 6 E/ P- P! R. w- t" F3 U% @
75.什么是lambda函数? 有什么好处?
3 w0 l4 O6 S7 f& Z3 u5 W 4 h+ v" ~' \/ a9 k7 x2 o
& H! c8 J& ]+ b) k5 Z
lambda 函数是一个可以接收任意多个参数(包括可选参数)并且返回单个表达式值的函数
* t' N. ?; f& x E' [) b' { p ( I: V, v) X: C! T8 Z* b1 O
/ Y/ V' N* z) O8 ~
1.lambda函数比较轻便,即用即仍,很适合需要完成一项功能,但是此功能只在此一处使用,连名字都很随意的情况下 0 W4 \( A% z' @! w! Q9 W6 E
2.匿名函数,一般用来给filter,map这样的函数式编程服务
9 r- e; [7 {" }/ p2 U; C6 e+ G 3.作为回调函数,传递给某些应用,比如消息处理
: j4 t# j/ }/ J# O9 D }! k# V( | ————————————————
) z) W& q, O. Q& M$ {" e% o* d 版权声明:本文为CSDN博主「yk 坤帝」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
5 K* o" P% v$ V d* D. W 原文链接:https://blog.csdn.net/qq_45803923/article/details/117754922
/ g% b2 L" f3 J $ w* ~& h$ W# O9 [ D/ D8 l+ f
7 m1 Q/ u) z3 I& w* ]2 @5 s
zan