小黑尝试乐城堡数据开发笔试题校招,加油~

(一)

1.统计域名
# 1.计算多少个是以domain1.com结尾的
# 记录每一行的信息
lines = ['47.29.201.179	-	-	[28/Feb/2019:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	200	5316	"https://domain1.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
        '47.29.201.179	-	-	[28/Feb/2019:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	200	5316	"https://domain1.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
         '47.29.201.179	-	-	[28/Feb/2019:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	404	5316	"https://domain.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
         '47.29.201.179	-	-	[2/Match/2019:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	200	5316	"https://domain.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
        ]
sum_ = 0
for line in lines:
    _nodes = line.split()
    url = _nodes[10]
    matchs = re.findall('domain1\.com',url)
    if matchs:
        sum_ += 1
print('domain1.com为域名的个数:',sum_)

domain1.com为域名的个数: 2

2.计算成功比例
# 筛选出成功的比例
import datetime
from datetime import datetime as dt
lines = ['47.29.201.179	-	-	[17/Nov/2022:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	200	5316	"https://domain1.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
        '47.29.201.179	-	-	[17/Nov/2022:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	200	5316	"https://domain1.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
         '47.29.201.179	-	-	[17/Nov/2022:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	404	5316	"https://domain1.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
         '47.29.201.179	-	-	[2/Mar/2019:13:17:10	+0000]	"GET	/?p=1	HTTP/2.0"	200	5316	"https://domain1.com/?p=1"	"Mozilla/5.0	(Windows	NT	6.1)	AppleWebKit/537.36	(KHTML,	like	Gecko)	Chrome/72.0.3626.119	Safari/537.36"	"2.75"',
        ]
# 给定今日时间
now_time = dt.now()
# 给定日子的所有请求数量
total = 0
# 给定日子的所有成功请求(200)的数量
success = 0
for line in lines:
    # 获取每一行时间
    _nodes = line.split()
    Time= _nodes[3][1:-1].replace(":"," ",1)
    Time = dt.strptime(Time,"%d/%b/%Y %H:%M:%S")
    # 选择今天的请求
    if Time.year == now_time.year and Time.month == now_time.month and Time.day == now_time.day:
        total += 1
        status = _nodes[8]
        # 判断是否成功
        if status == '200':
            success += 1
print('案例中当日(2022/11/17)成功的比例为:',success/total)

案例中当日(2022/11/17)成功的比例为: 0.6666666666666666

(二)

SELECT COUNT(*) FROM event_log WHERE event_timestamp >= UNIX_TIMESTAMP('2020-09-01') AND event_timestamp < UNIX_TIMESTAMP('2020-10-01') GROUP BY user_id HAVING COUNT(*) >= 1000 and COUNT(*) < 2000;

(三)在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值