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

题目:

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

处理: 

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]))

总结

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

在此谢过

猜你喜欢

转载自www.cnblogs.com/Alwaysblue/p/12177210.html