错误记录功能小模块

题目描述:
开发一个简单错误记录功能小模块,能够记录出错的代码所在的文件名称和行号。
处理:
1、 记录最多8条错误记录,循环记录,对相同的错误记录(净文件名称和行号完全匹配)只记录一条,错误计数增加;

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

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

输入描述:
一行或多行字符串。每行包括带路径文件名称,行号,以空格隔开。
输出描述:
将所有的记录统计并将结果输出,格式:文件名 代码行数 数目,一个空格隔开,如:
示例1
输入

复制
E:\V1R2\product\fpgadrive.c 1325
输出

复制
fpgadrive.c 1325 1

#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>
#include <string.h>
#include <math.h>
typedef struct {
 char str[200];
 int num;
 int count;
}error_log;
int main(){

    char str[1000];
    int i,j,k,len,arrcnt=0;
    error_log *log[1000],*temp;
    char *p;
    temp=(error_log *)malloc(sizeof (error_log));
    while(scanf("%s %d",temp->str,&(temp->num))!=EOF)
    {
      p=strrchr(temp->str,'\\');
      p=p+1;
      len=strlen(p);
      if(len>16)
        p=p+len-16;

      for(i=0;i<arrcnt;i++)
      {
          if(strcmp(log[i]->str,p)==0)
          {
              if(log[i]->num==temp->num)
              {
                  (log[i]->count)++;
                   break;//这里break 的意思是,如果有一样的,那么就跳出直接终止
                   //也就只可能出现相同的一次,后面不可能还有一模一样的。
                   //同时这里的i也没有++,所以后面是不会把他写进数组里面的
              }
          }

      }
     if(arrcnt==i)
      {
         log[arrcnt]=(error_log *)malloc(sizeof (error_log));//把传输进来的每个字符串
         //都复制到log数组中
         strcpy(log[arrcnt]->str,p);
         log[arrcnt]->num=temp->num;
         log[arrcnt]->count=1;
         arrcnt++;
      }
    }

    if(arrcnt>8)
     j=arrcnt-8;//同样的这里也是,如果超过8那么就取后面的8个。
     else j=0;
     for(;j<arrcnt;j++)
      printf("%s %d %d\n",log[j]->str,  log[j]->num,log[j]->count);
    return 0;
}

在这个代码中只是以文件名的后16个字符为判断条件,并不检查前面是否一样。就把它们归为一样了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Python的traceback模块来实现一个简单错误记录功能模块。该模块提供了一些函数来跟踪和记录Python程序的异常信息。 首先,我们可以在产生错误的地方调用`traceback.format_exc()`函数,该函数会返回一个字符串,包含当前错误的堆栈跟踪信息。我们可以将这个字符串记录下来。 然后,我们可以使用`sys.exc_info()`函数来获取当前的异常信息。该函数返回一个元组,包含当前异常的类型、错误对象和跟踪对象。我们可以从跟踪对象中获取错误发生的文件名和行号信息。 接下来,我们可以将错误信息和堆栈跟踪信息写入一个文件或者输出到控制台。 下面是一个简单实现的示例代码: ```python import traceback import sys def log_error(): try: # 让程序产生一个错误 raise ValueError('示例错误') except: # 获取错误信息 error_type, error_value, error_traceback = sys.exc_info() # 获取错误发生的文件名和行号信息 file_name = traceback.extract_tb(error_traceback)[-1].filename line_number = traceback.extract_tb(error_traceback)[-1].lineno # 将错误信息和堆栈跟踪信息记录下来 error_message = f'错误类型:{error_type}\n错误内容:{error_value}\n文件名:{file_name}\n行号:{line_number}\n堆栈跟踪:\n{traceback.format_exc()}' with open('error_logs.txt', 'a') as f: f.write(error_message + '\n') # 或者直接输出到控制台 print(error_message) # 调用函数进行错误记录 log_error() ``` 运行以上代码后,程序会产生一个错误,并记录错误信息、错误文件名、行号和堆栈跟踪信息到名为`error_logs.txt`的文件中。你可以根据实际情况修改日志记录的方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值