24秋学期(高起本:1809-2103、专升本/高起专:2103)《网络爬虫与信息提取》在线作业-00003* U3 ? s& \1 u% h- V8 M; c' k! G
试卷总分:100 得分:100 l5 _7 x0 y) ^$ ~( h5 [" V' w, ?% w+ U
咨询:ffffd79) j" m6 `! v6 O0 }* K" d" r
一、单选题 (共 20 道试题,共 40 分)
' ?! y' t% M* H( K: @1.Python中若定义object=(1, 2, 3, 4, 5),则print(object[1:3])输出(). c- h) F8 k1 G
A.12
7 J. b& \+ X7 w* `- VB.1239 ^( V) X5 z5 w* v
C.23/ i- g. n7 r7 {8 l
D.234/ M0 Y. Z, z1 V }2 |" [; H
2.如果使用Python的数据结构来做类比的话,MongoDB中文档相当于一个()
8 A& ?% A) I; E8 sA.列表$ F* X6 X7 f+ `0 V" T/ p% E
B.元组' j! F7 U2 J( @0 \/ c& _7 `
C.字典* e! Z3 l; P9 h1 r, Z4 c T
D.集合5 Z( V& ~) W* u, ^/ i' x
3.Redis中如果不删除列表中的数据,又要把数据读出来,就需要使用关键字()0 A* V, n" P5 I% i/ l; y
A.range% h$ Q) }3 K4 w* g! Q+ |# M1 [! ]
B.lrange
6 s2 v- H! I2 z/ l/ n! c* NC.srange
& x3 K& i8 x2 d6 |. F4 o7 uD.pop
6 P3 j3 Z, `5 k$ l' V4.使用UI Automator打开微信的操作是获取相应图标后使用命令(); {* M G m% n1 x* w
A.touch- h. q. c1 V* t
B.click
. T7 p: y5 M' m' q; u. z+ yC.push* S! l. W" l/ q4 X
D.hover
' Z; @; G& s% h; W- X5 x6 ]% X5.Python正则表达式模块的findall方法提取内容包含多个,则返回结果的列表中会包含()
/ k3 D# U: g9 }6 M3 dA.列表9 U" X; H& M3 K: e6 R5 `) n
B.元组
5 H; `. K' S: }C.字典
- R7 \3 K# E k9 B; N' x: xD.集合
7 B3 S1 Y7 d, W5 Z; G* e6.使用UI Automatorr根据坐标来滑动桌面的操作是得到相应控件后使用命令()
8 y7 x+ t$ I# L& ^- E0 TA.swipe
) d F1 T1 `8 i- o/ V+ b( h3 _B.move% }+ v4 B' h; x0 n9 F
C.scroll, [+ ~# o5 M l( ]+ w0 l; ?
D.fly$ w# B9 z& i# t* E' Z
7.MongoDB中数据存储的形式类似于()
9 f' P3 [5 H9 @1 \5 SA.列表
8 y3 W. y% E) s; sB.元组
# A ~/ j _0 k: u. VC.字典
* r) ~( S9 j" Z5 d6 L5 ~6 LD.集合
3 V7 _% {& ~7 C; K! R3 e% F8.通常使用()工具来模拟浏览器进行爬虫请求% y* q" Y* M& q. @ ~+ @# a
A.Selenium
: [( p6 C: D2 U. yB.Chrome: D# I2 U! f: D! s
C.ChromeDriver
; _5 P4 E. j/ M6 L1 ]* b0 _D.WebDriver
, ^ U6 g8 q }% u2 S" a" @9.下列哪项不是HTTP的请求类型()
& w+ n9 q: ?: L* Z6 q2 vA.GET
7 R, f' l4 L! g2 b# QB.POST
A% q4 r3 }7 d& i R8 CC.PUT+ @: p4 o; A* |) S1 Z, Z" W+ `
D.SET, v0 I$ K, A2 R$ a8 {6 O! v
10.Redis中写数据到列表中,使用关键字()
# C$ u* N" G( x7 _A.push* X5 d* C. b( ^6 R
B.append" X' i$ e2 d1 j, `, ^+ G a
C.lpush
: Z5 B* }, N+ t8 ?, }+ D# r j) xD.lappend0 b& y# P }4 }& p0 o9 V. V; l2 P, a
11.Redis中读取数据语句lrange chapter 0 3,那么表示读列表中()个值
) T7 z& \2 B8 `A.2# h, p: r/ D r
B.3
7 X4 s3 L" x& s: P" PC.46 g( x3 T/ i' Y ?2 W
D.5
- J: D6 r/ Y! [6 U12.查看网站请求一般在Chrome开发者模式下的()选项卡中查看5 a* H# Z. F! N, R
A.Console; ~$ v$ _3 C1 R" O* l. i
B.Sources
8 l) L, \. O x' B: g8 LC.Network) q* R; x5 Y: y+ c/ I
D.Performance
; q! _0 U" F) o7 h. I/ _13.在Python中,为了使用XPath,需要安装一个第三方库(). W; ]5 o- b G: i4 z
A.lxml
3 D9 u+ M1 ^3 q8 ~B.xml$ I7 w* E4 Q2 ~* i J* F+ I* x
C.xpath' z V& u1 }4 W- D
D.path
6 e9 ?; V2 l# u. A0 d14.Python中Object=(1, 2, 3, 4, 5),则Objcet是()
$ R: k% Y. D, K8 r9 B# aA.列表
! d% X7 U Q' QB.元组$ J+ D( B! `- |1 f& b
C.字典9 n1 c+ y2 u- D1 J0 ~) L( n/ H6 Q
D.集合
% o/ L' Z3 ?9 @: H& v6 L- s: i15.使用UI Automatorr点亮屏幕的操作是得到相应控件后使用命令()
) G0 X3 n8 K' KA.wakeup
) M4 H3 w( `7 S/ [6 m1 O. XB.light" u; }& D' Y- g: K
C.bright* {$ Z$ c' g, g6 k$ O2 x" @' _7 U) T
D.sleep
3 G( H5 M9 u5 ~* G% Y+ C5 H' i7 V8 L$ d/ N16.当爬虫运行到yield scrapy.Request()或者yield item的时候,下列哪个爬虫中间件的方法被调用?
3 R2 K$ A! x2 ~4 }$ N9 dA.process_spider_output() a, a. U8 [1 r* Q$ h
B.process_spider_exception()
- r$ B8 k0 p: P2 I$ {3 z1 qC.process_spider_input()
% X0 `, d5 H) e- a. ]+ u+ sD.process_start_ requests()
* c) }: G( p6 N0 g: G1 H# q& K17.HTTP状态码401表示
7 A2 |4 v5 U, f3 Y# X9 w2 ^! MA.请求报文中可能存在语法错误
, J2 t( Z+ E# [B.请求需要通过HTTP认证
: I k3 z1 }; U& ^; ~$ J" J0 fC.请求资源的访问被拒绝' H! G' G( l2 |' J2 n1 f
D.服务器上没有请求的资源
. f+ q) q# Y+ i- u6 p18.windows中创建定时任务的命令为
9 D1 P: h4 D2 C# @# l$ B/ Z% bA.task
+ B0 ~& j$ s# L9 J5 Z8 BB.schtasks0 G& c! u1 n0 u8 Y' ^+ F
C.createtasks" n9 U7 T9 O7 ~
D.maketasks/ W$ E5 m% ?6 W) }
19.Python中若定义object=[1, 2, 3, 4, 5],则print(object[-4])输出()- W5 k4 n! T$ \4 G
A.NULL, q3 k. `4 ~9 n+ t t8 G
B.2
( v) ?$ D+ {3 L6 {. GC.40 G4 }7 f n$ r* a. A* t
D.程序报错0 c( Z* c0 W, y: x5 V/ @1 X; C
20.在Scrapy的目录下,哪个文件负责存放爬虫文件?()
X+ S, k! J2 [+ U$ {2 k- mA.spiders文件夹
+ ?2 q$ Y- j4 m+ c* zB.item.py
" B4 `4 w( l; s) D- IC.pipeline.py! c/ U ^# r1 R/ Z( s2 `
D.settings.py4 a+ \. m- \ }6 a
二、多选题 (共 10 道试题,共 20 分)
/ O% X4 r: f# A1 p# c% b8 H( [ B; y21.在配置ios使用Charles的操作中,正确的有()
& Y5 }' C8 S0 dA.对于苹果设备,首先要保证计算机和苹果设备联在同一个Wi-Fi上。
+ c5 ]& T% s& n' qB.选择“HTTP代理”下面的“手动”选项卡,在“服务器”处输入计算机的IP地址,在“端口”处输入8888
3 H. x4 w3 k! s3 ]4 M5 x9 oC.输入完成代理以后按下苹果设备的Home键,设置就会自动保存。, F3 M: s9 S6 z3 W) j
D.安装完成证书以后,在设置中打开“关于本机”,找到最下面的“证书信任设置”,并在里面启动对Charles证书的完全信任* v) l; j* T( L/ O% R
22.一个可行的自动更换代理的爬虫系统,应该下列哪些功能?
' k% F9 _; e" U% E% V) PA.有一个小爬虫ProxySpider去各大代理网站爬取免费代理并验证,将可以使用的代理IP保存到数据库中% ]' y& B3 x; t3 r
B.在发现某个请求已经被设置过代理后,什么也不做,直接返回+ G% z" a; @# ~/ Z/ r
C.在ProxyMiddlerware的process_request中,每次从数据库里面随机选择一条代理IP地址使用
- S1 m* |8 M- _& T4 E4 H& L2 PD.周期性验证数据库中的无效代理,及时将其删除
1 R/ S7 A$ Z3 a. \7 _; n23.HTTP常用状态码表明表明客户端是发生错误的原因所在的有()8 o0 R0 N, v) v8 Z* H6 u
A.403+ L' U; P$ J1 y- D; c0 e; Z
B.404
; D2 [# b, h |C.500
( R5 b, H: V& U+ H7 AD.503
6 a% n; E! D& O4 E- b24.cookies的缺点是5 x3 `' ?$ B D; w7 L
A.实现自动登录" `5 V! w; Q D4 w* r6 @: f
B.跟踪用户状态
! l( _0 w- T. _& g7 u0 MC.http中明文传输
2 d- H5 N4 v Z! e5 wD.增加http请求的流量: \ ?, }: K) D
25.requests中post请求方法的第二个参数可以为()$ o6 @$ F6 B& `+ _$ `% T: L, ?2 {3 J
A.字典& o9 F& O! X7 {3 f; R
B.列表7 i1 A. ^7 j. v
C.json数据6 T# I' O' F; I; J
D.字符串6 b1 w6 H7 J/ i9 R* y: e4 V
26.Python中()容器有推导式
: \/ f, H9 i5 Q3 NA.列表5 f3 P& p, X7 j) p1 K+ D. Y+ P
B.元组
U9 y" f. C# s. ^ Z4 v- Q! q' R! XC.字典
9 ^1 Y, H* p! I9 }6 F2 ?D.集合
9 ^" U$ F1 R/ Z$ j' ?27.以下HTTP状态码表示服务器没有正常返回结果的是
! s( ^ R: V9 p& O& t8 t/ r9 HA.200
$ i" T/ N: Q3 }! F' jB.301
z. x5 U! p9 z0 A4 B, P" kC.404- {+ O, E% c T7 n
D.5005 ^2 | o0 Q0 ?* k5 r& A9 f+ d' u( b
28.如果爬虫爬取的是商业网站,并且目标网站使用了反爬虫机制,那么强行突破反爬虫机制可能构成()
4 L8 [' n, R* @& k$ y4 KA.非法侵入计算机系统罪
( T: y8 V, U5 R* S/ v- b0 GB.非法获取计算机信息系统数据罪7 |1 h. {" Y5 H# N4 O& V
C.非法获取计算机数据罪$ c$ G8 u7 y" X9 H$ C
D.非法获取系统罪
. F: I1 v% `, _) u29.Python中通过Key来从字典object中读取对应的Value的方法有()5 F$ [7 e7 G. y2 g1 k @
A.object[key]
4 N1 T& _4 X* a6 PB.object.get(key). i4 h7 r7 d% N, c& e1 `- Q
C.object.pop(key)
3 K! A0 Q7 I5 S; c uD.object.pop()
) Q7 Z4 }9 ?, K1 P* t& \( [1 b30.Python中一个函数可以有()个return语句8 l( Y9 h% I: O7 G
A.0
$ L6 R h) b4 GB.1
& |: j- t0 C) mC.多个1 V" F% `8 w) i9 u/ Y. W# u& _0 q
D.2
- @$ c0 b& t& G g- K三、判断题 (共 20 道试题,共 40 分)
! ~0 C }; k4 |7 d' m( @$ u, f' O: ^31.Python中使用下面代码打开文件也需要对文件进行close关闭操作 with open('文件路径', '文件操作方式', encoding='utf-8') as f5 m+ {! }: z9 X& P$ [) O* D; q
32.使用异步加载技术的网站,被加载的内容可以在源代码中找到" T7 m" R3 j1 F3 Y8 ~
33.cookies在http请求中是明文传输的。
* E. [, N( h( `: G34.上课传纸条中,传递纸条的人就可以发起中间人攻击。
, J# w# N2 ]1 [, f* @. \35.如果通过爬虫抓取某公司网站的公开数据,分析以后发现这个公司业绩非常好。于是将数据或者分析结果出售给某基金公司,从而获得销售收入。这是合法的。
+ M! U* A/ e" y+ K8 m L% D) M36.在有spiders何setting.py这两项的情况下,可以写出爬虫并且保存数据,items.py和pipelines.py文件是原作者的失误而导致的冗余文件。2 H5 e; A0 ^# V3 ]9 o# A" d1 F
37.当使用Scarpy创建爬虫时,当爬取网易云音乐首页信息时,scrapy genspider的第二个参数直接输入"163.com"就可以了
1 A+ M4 g% E: G0 ^3 r: l38.当使用Charles监控iOS设备或者Android设备的数据包以后,打开微信小程序,小程序的数据包不能自动被Charles抓住,需要另作处理。
/ r( d6 C( m9 g7 u8 C8 i: w7 s6 p39.HTTP状态码中303状态码明确表示客户端应当采用POST方法获取资源
0 S" Y0 e T- A2 f, p, K( T40.通用网络爬虫通常采用串行工作方式. g7 r& K+ B! j% p$ y2 u, {& |0 c
41.为了保证数据插入效率,在内存允许的情况下,应该一次性把数据读入内存,尽量减少对MongoDB的读取操作。
) C' H; U" L6 L: o2 j42.中间人爬虫就是利用了中间人攻击的原理来实现数据抓取的一种爬虫技术
% ^9 ] K4 R( h* @4 H43.Scrapy的工程名字不能使用"scrapy",否则爬虫会无法运行。除此以外工程名不受限制。
1 m( Z* _# Y3 i# X; C6 i2 w44.通用搜索引擎的目标是尽可能大的网络覆盖率,搜索引擎服务器资源与网络数据资源互相匹配
f7 x$ ? h# e+ Y0 P1 l: F# [45.Python中写CSV文件的writerows方法参数为字典类型. c% z( h7 J w! m( B
46.中间人攻击也是抓包的一种。4 C- |8 K) D' V4 q
47.验证码必须通过手动填充识别。
( `, n! C( n& o" X& f48.XPath提取出来的内容是一个SelectorList对象,它的第0个元素就是网页的源代码。+ W+ l8 N6 y: c
49.Linux环境中,Virtualenv创建的虚拟Python环境中,执行pip命令安装第三方库就不需要使用sudo命令了。# d/ S6 _% w3 W4 x" @
50.使用AJAX技术,可以在不刷新网页的情况下更新网页数据 |