首页 > 编程语言 > 详细

华为机试题-简单错误记录python 实现

时间:2020-01-10 19:26:46      阅读:329      评论:0      收藏:0      [点我收藏+]

题目:

开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。

 

处理: 

 

1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;

 

2、 超过16个字符的文件名称,只记录文件的最后有效16个字符;

 

3、 输入的文件可能带路径,记录文件名称不能带路径。

 

输入描述:

一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。

输出描述:

将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开

 

思路:

<<分割输入字符串,得到文件名、错误行

<<判断文件名长度,并将文件名存到queue中

<<定义一个dictionary 存储文件名错误信息次数

<<判断文件名是否已经被记录过

代码:

#!/usr/bin/python
# -*- coding: utf-8 -*-
import sys
import queue

q=queue.Queue(maxsize=8)
filelist=[]
dic={}
while True :
    Input = sys.stdin.readline().strip()
    if Input==‘‘:
        break
    tempList=Input.split(\\)
    file=tempList[len(tempList)-1]
    fileName=file.split( )[0]
    line=file.split( )[1]
    if len(fileName)>16:
        fileName=fileName[-16:]
        file=fileName+" "+line
    if file in dic:
        dic[file]+=1
    else:
        if q.full():
            q.get()
        q.put(file)
        dic[file]=1
for i in range(8):
    f1=q.get()
    print({0} {1}.format(f1,dic[f1]))

总结

这道题不难,第一次做借鉴了其他人的方法用的列表存储了所有的记录,最后输出后八个,单纯以做题为目的的话没什么问题,但是实际工程中这样做的话那肯定是错的,由于时间的积累,这个记录会越来越大,之前做上位机的话报警信息都是存在数据库里,如果在工程上要做这种错误记录方式的话感觉用队列会更好,所以又尝试用队列做了一遍,时间上比列表满了不少,希望有技术大牛能解释下!

在此谢过

华为机试题-简单错误记录python 实现

原文:https://www.cnblogs.com/Alwaysblue/p/12177210.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!