Linux下控制(统计)文件的生成的C代码实现

开发 开发工具
这篇文章主要介绍Linux下控制(统计)文件的生成的C代码实现。

需求描述

不定时地在Linux机器下的某目录中放入文件,文件内容中包含了用户号码、起止时间等字段,现要求编写一程序来统计目前该目录中所有文件中的记录总条数及所有记录中的最早起始时间和最晚结束时间。

例如,该目录中有两个文件Test_1.txt和Test_2.txt,其中Test_1.txt文件内容为:

  1. 15696192591|15696192592|20151103 120909|20151103 201545|  
  2. 15696192593|15696192594|20151103 110909|20151103 191545|  
  3. 02344273522|02344273523|20160108 110909|20160109 091545| 

Test_2.txt文件内容为:

  1. 15696192595|15696192596|20151102 120909|20151104 201545|  
  2. 15696192597|15696192598|20151101 110909|20151103 191545| 

即文件中的每条记录的格式为:呼叫号码|被呼叫号码|呼叫起始时间|呼叫结束时间|,要求生成的控制文件CtlFile.txt的内容为:

  1. 20151101 110909|20160109 091545|5| 

即Test_1.txt和Test_2.txt两个文件中五条记录的开始时间的最小值为“20151101 110909”,结束时间的***值为“20160109 091545”,目前共处理了5条记录。也就是说,控制文件的格式为:呼叫起始时间最小值|呼叫结束时间***值|记录总条数|。

代码

程序代码

本程序一共包括了三个代码文件:main.c、CtlFileCreate.c和CtlFileCreate.h,具体代码如下:

main.c

  1. /********************************************************************** 
  2. * 版权所有 (C)2016, Zhou Zhaoxiong。 
  3. * 文件名称:CtlFileCreate.c 
  4. * 文件标识:无 
  5. * 内容摘要:目录中文件的读取及控制文件的生成 
  6. * 其它说明:无 
  7. * 当前版本:V1.0 
  8. * 作    者:Zhou Zhaoxiong 
  9. * 完成日期:20160109 
  10. **********************************************************************/ 
  11. #include "CtlFileCreate.h" 
  12.  
  13. /********************************************************************** 
  14. * 功能描述:主函数 
  15. * 输入参数:无 
  16. * 输出参数:无 
  17. * 返 回 值:无 
  18. * 其它说明:无 
  19. * 修改日期        版本号      修改人            修改内容 
  20. * ------------------------------------------------------------------- 
  21. * 20160109        V1.0     Zhou Zhaoxiong        创建 
  22. ***********************************************************************/ 
  23.  
  24. INT32 main() 
  25.     ReadCtlFile();    // 获取控制文件存放路径、控制文件全路径名及文件内容字段值 
  26.  
  27.     ReadSrcFileAndWriteCtlFile();    // 扫描源文件目录, 并写控制文件 
  28.  
  29.     return 0; 

CtlFileCreate.h

  1. /********************************************************************** 
  2. * 版权所有 (C)2015, Zhou Zhaoxiong。 
  3. * 文件名称:CtlFileCreate.h 
  4. * 文件标识:无 
  5. * 内容摘要:目录中文件的读取及控制文件的生成 
  6. * 其它说明:无 
  7. * 当前版本:V1.0 
  8. * 作    者:Zhou Zhaoxiong 
  9. * 完成日期:20151102 
  10. **********************************************************************/ 
  11. #include <stdio.h> 
  12. #include <stdlib.h> 
  13. #include <string.h> 
  14. #include <dirent.h> 
  15.  
  16. // 数据类型重定义 
  17. typedef unsigned char       UINT8; 
  18. typedef unsigned short int  UINT16; 
  19. typedef unsigned int        UINT32; 
  20. typedef signed   int        INT32; 
  21. typedef unsigned char       BOOL; 
  22.  
  23. // 参数类型 
  24. #define MML_INT8_TYPE       0 
  25. #define MML_INT16_TYPE      1 
  26. #define MML_INT32_TYPE      2 
  27. #define MML_STR_TYPE        3 
  28.  
  29. #define  TRUE         (BOOL)1 
  30. #define  FALSE        (BOOL)0 
  31.  
  32. // 字段***长度 
  33. #define MAX_RET_BUF_LEN     1024 
  34.  
  35. // 源文件字段结构体 
  36. typedef struct 
  37.     UINT8 szSrcNumber[50]; 
  38.     UINT8 szDstNumber[50]; 
  39.     UINT8 szDataStartTime[50];  
  40.     UINT8 szDataEndTime[50];  
  41. } T_SrcFileContent; 
  42.  
  43. // 函数声明 
  44. void Sleep(UINT32 iCountMs); 
  45. void ReadCtlFile(void); 
  46. void ReadSrcFileAndWriteCtlFile(void); 
  47. void GetSrcFileContentAndWriteCtlFile(UINT8 *pszSrcFileName); 
  48. void GetSrcFileFieldValue(UINT8 *pszContentLine, T_SrcFileContent *ptSrcFileContent); 
  49. void GetCtlFileContentAndWrite(T_SrcFileContent *ptSrcFileContent, UINT8 *pszContentBuffer); 
  50. BOOL GetValueFromStr(UINT16 iSerialNum, UINT8 iContentType, UINT8 *pSourceStr, UINT8 *pDstStr, UINT8 cIsolater, UINT32 iDstStrSize); 
  51. void RemoveLineEnd(UINT8 *pszStr); 
  52. void WriteToCtlFile(UINT8 *pszContentLine);  

CtlFileCreate.c

  1. /********************************************************************** 
  2. * 版权所有 (C)2015, Zhou Zhaoxiong。 
  3. * 文件名称:CtlFileCreate.c 
  4. * 文件标识:无 
  5. * 内容摘要:目录中文件的读取及控制文件的生成 
  6. * 其它说明:无 
  7. * 当前版本:V1.0 
  8. * 作    者:Zhou Zhaoxiong 
  9. * 完成日期:20151102 
  10. **********************************************************************/ 
  11. #include "CtlFileCreate.h" 
  12.  
  13. // 全局变量 
  14. UINT8  g_szSourceDir[500]    = {0};         // 需扫描的源目录 
  15. UINT8  g_szCtlFileDir[500]   = {0};         // 生成的控制文件的存放目录 
  16. UINT8  g_szSourceBakDir[500] = {0};         // 处理之后的源文件的备份目录 
  17. UINT8  g_szCtlFileName[256]  = {0};         // 控制文件全路径名 
  18. UINT8  g_szDataStartTime[50] = {0};         // 所有源文件中数据记录的最早开始时间 
  19. UINT8  g_szDataEndTime[50]   = {0};         // 所有源文件中数据记录的最晚结束时间 
  20. UINT32 g_iRecordsSum         = 0;           // 已处理的记录的总条数 
  21.  
  22. /********************************************************************** 
  23. * 功能描述: 读取控制文件中的开始时间、结束时间和记录条数 
  24. * 输入参数: 无 
  25. * 输出参数: 无 
  26. * 返 回 值: 无 
  27. * 其它说明: 无 
  28. * 修改日期          版本号       修改人              修改内容 
  29. * ------------------------------------------------------------------ 
  30. * 20151102          V1.0     Zhou Zhaoxiong           创建 
  31. ********************************************************************/ 
  32. void ReadCtlFile(void) 
  33.     UINT8 *pszHomePath = NULL;  
  34.     FILE  *fpCtlFile   = NULL
  35.     UINT8  szBuf[500]  = {0};  
  36.  
  37.     // 读取控制文件中的开始时间、结束时间和记录条数, 如果是当天程序重启, 则记录条数继续编号 
  38.     pszHomePath = getenv("HOME"); 
  39.     if (pszHomePath == NULL) 
  40.     { 
  41.         return; 
  42.     } 
  43.  
  44.     snprintf(g_szCtlFileDir, sizeof(g_szCtlFileDir)-1, "%s/zhouzhaoxiong/zzx/CtlFileCreate/CtlFile", pszHomePath);  // 控制文件存放目录 
  45.  
  46.     snprintf(g_szCtlFileName, sizeof(g_szCtlFileName)-1, "%s/CtlFile.txt", g_szCtlFileDir);  // 控制文件全路径名 
  47.  
  48.     fpCtlFile = fopen(g_szCtlFileName, "r"); 
  49.     if (fpCtlFile != NULL) 
  50.     { 
  51.         fgets(szBuf, sizeof(szBuf), fpCtlFile); 
  52.  
  53.         // 获取开始时间g_szDataStartTime 
  54.         if (TRUE != GetValueFromStr(1, MML_STR_TYPE, szBuf, g_szDataStartTime, '|', sizeof(g_szDataStartTime))) 
  55.         { 
  56.             printf("ReadCtlFile: exec GetValueFromStr to get g_szDataStartTime failed!\n"); 
  57.             return; 
  58.         } 
  59.  
  60.         // 获取结束时间g_szDataEndTime 
  61.         if (TRUE != GetValueFromStr(2, MML_STR_TYPE, szBuf, g_szDataEndTime, '|', sizeof(g_szDataEndTime))) 
  62.         { 
  63.             printf("ReadCtlFile: exec GetValueFromStr to get g_szDataEndTime failed!\n"); 
  64.             return; 
  65.         } 
  66.  
  67.         // 获取记录条数g_iRecordsSum 
  68.         if (TRUE != GetValueFromStr(3, MML_INT32_TYPE, szBuf, (UINT8 *)&g_iRecordsSum, '|', sizeof(g_iRecordsSum))) 
  69.         { 
  70.             printf("ReadCtlFile: exec GetValueFromStr to get g_iRecordsSum failed!\n"); 
  71.             return; 
  72.         } 
  73.  
  74.         fclose(fpCtlFile); 
  75.         fpCtlFile = NULL
  76.  
  77.         printf("ReadCtlFile: DataStartTime=%s, DataEndTime=%s, RecordsSum=%d\n", g_szDataStartTime, g_szDataEndTime, g_iRecordsSum); 
  78.     } 
  79.  
  80.  
  81. /********************************************************************** 
  82. * 功能描述: 扫描源文件目录, 并写控制文件 
  83. * 输入参数: 无 
  84. * 输出参数: 无 
  85. * 返 回 值: 无 
  86. * 其它说明: 无 
  87. * 修改日期          版本号       修改人              修改内容 
  88. * ------------------------------------------------------------------ 
  89. * 20151102          V1.0     Zhou Zhaoxiong           创建 
  90. ********************************************************************/ 
  91. void ReadSrcFileAndWriteCtlFile(void) 
  92.     UINT8 *pszHomePath        = NULL;  
  93.     UINT8  szCommandBuf[500]  = {0};  
  94.     UINT8  szSrcFile[500]     = {0};  
  95.  
  96.     DIR            *pDir    = NULL
  97.     struct dirent  *pDirent = NULL
  98.  
  99.     pszHomePath = getenv("HOME"); 
  100.     if (pszHomePath == NULL) 
  101.     { 
  102.         return; 
  103.     } 
  104.  
  105.     snprintf(g_szSourceDir,    sizeof(g_szSourceDir)-1,    "%s/zhouzhaoxiong/zzx/CtlFileCreate/SrcFile", pszHomePath);      // 源文件存放目录 
  106.  
  107.     snprintf(g_szSourceBakDir, sizeof(g_szSourceBakDir)-1, "%s/zhouzhaoxiong/zzx/CtlFileCreate/SrcFile_bak", pszHomePath);  // 源文件备份目录 
  108.  
  109.     while (1) 
  110.     {    
  111.         pDir = opendir(g_szSourceDir); 
  112.         if (NULL == pDir) 
  113.         { 
  114.             printf("ReadSrcFileAndWriteCtlFile: pDir is NULL!\n"); 
  115.             continue; 
  116.         } 
  117.  
  118.         while ((pDirent = readdir(pDir)) != NULL)    // 扫描源目录, 获取文件名 
  119.         { 
  120.             if (strncmp(pDirent->d_name, "Test_", strlen("Test_")) == 0)      // 如果匹配上了源文件的前缀, 则读取文件内容并写控制文件 
  121.             { 
  122.                 memset(szSrcFile, 0x00, sizeof(szSrcFile)); 
  123.                 snprintf(szSrcFile, sizeof(szSrcFile)-1, "%s/%s", g_szSourceDir, pDirent->d_name, g_szSourceBakDir); 
  124.                 GetSrcFileContentAndWriteCtlFile(szSrcFile);     // 获取源文件中的内容, 并写控制文件 
  125.  
  126.                 // 处理完成之后, 将文件剪切到备份目录中 
  127.                 memset(szCommandBuf, 0x00, sizeof(szCommandBuf)); 
  128.                 snprintf(szCommandBuf, sizeof(szCommandBuf)-1, "mv %s %s", szSrcFile, g_szSourceBakDir); 
  129.                 system(szCommandBuf); 
  130.                 printf("ReadSrcFileAndWriteCtlFile: now, move %s to %s\n", pDirent->d_name, g_szSourceBakDir); 
  131.             } 
  132.         } 
  133.  
  134.         closedir(pDir); 
  135.         pDir = NULL
  136.  
  137.         Sleep(60 * 1000);    // 每1分钟扫描一次 
  138.     } 
  139.  
  140.  
  141. /********************************************************************** 
  142. * 功能描述: 获取源文件中的内容, 并写控制文件 
  143. * 输入参数: pszSrcFileName-带路径的源文件名 
  144. * 输出参数: 无 
  145. * 返 回 值: 无 
  146. * 其它说明: 无 
  147. * 修改日期          版本号       修改人              修改内容 
  148. * ------------------------------------------------------------------ 
  149. * 20151102          V1.0     Zhou Zhaoxiong           创建 
  150. ********************************************************************/ 
  151. void GetSrcFileContentAndWriteCtlFile(UINT8 *pszSrcFileName) 
  152.     FILE  *fp                  = NULL
  153.     UINT8  szContentLine[1024] = {0}; 
  154.  
  155.     T_SrcFileContent tSrcFileContent = {0}; 
  156.  
  157.     if (pszSrcFileName == NULL) 
  158.     { 
  159.         printf("GetSrcFileContentAndWriteCtlFile: pDir is NULL!\n"); 
  160.         return; 
  161.     } 
  162.  
  163.     if ((fp = fopen(pszSrcFileName, "r")) == NULL)  // 只读方式打开 
  164.     { 
  165.         printf("GetSrcFileContentAndWriteCtlFile: open src file failed!\n"); 
  166.         return;  
  167.     } 
  168.     else 
  169.     { 
  170.         while (feof(fp) == 0 && ferror(fp) == 0) 
  171.         { 
  172.             // 每行对应一条源文件记录 
  173.             memset(szContentLine, 0x00, sizeof(szContentLine)); 
  174.             if (fgets(szContentLine, sizeof(szContentLine), fp) == NULL) 
  175.             { 
  176.                 printf("GetSrcFileContentAndWriteCtlFile: exec fgets to get line null.\n"); 
  177.             } 
  178.             else 
  179.             { 
  180.                 printf("GetSrcFileContentAndWriteCtlFile: get content line: %s\n", szContentLine); 
  181.             } 
  182.  
  183.             RemoveLineEnd(szContentLine); // 去掉字符串后面的回车换行符 
  184.  
  185.             if (strlen(szContentLine) == 0)   // 如果为空行, 则继续处理下一条 
  186.             { 
  187.                 printf("GetSrcFileContentAndWriteCtlFile: the length of ContentLine is 0, continue.\n");  
  188.                 continue; 
  189.             } 
  190.  
  191.             GetSrcFileFieldValue(szContentLine, &tSrcFileContent);   // 获取一条记录中各个字段的值 
  192.  
  193.             memset(szContentLine, 0x00, sizeof(szContentLine)); 
  194.             GetCtlFileContentAndWrite(&tSrcFileContent, szContentLine); // 组装写入控制文件中的内容 
  195.  
  196.             WriteToCtlFile(szContentLine);    // 将内容写到控制文件中 
  197.         } 
  198.  
  199.         fclose(fp); 
  200.         fp = NULL
  201.     } 
  202.  
  203.  
  204. /********************************************************************** 
  205. * 功能描述: 组装写入控制文件中的内容 
  206. * 输入参数: ptSrcFileContent-源文件中一条记录中各个字段的值 
  207. * 输出参数: pszContentBuffer-存放内容的缓存 
  208. * 返 回 值: 无 
  209. * 其它说明: 控制文件中记录为: DataStartTime|DataEndTime|RecordsSum| 
  210. * 修改日期          版本号       修改人              修改内容 
  211. * ------------------------------------------------------------------ 
  212. * 20151102          V1.0     Zhou Zhaoxiong           创建 
  213. ********************************************************************/ 
  214. void GetCtlFileContentAndWrite(T_SrcFileContent *ptSrcFileContent, UINT8 *pszContentBuffer) 
  215.     UINT8  szContentLine[500] = {0}; 
  216.  
  217.     if (ptSrcFileContent == NULL || pszContentBuffer == NULL) 
  218.     { 
  219.         printf("GetCtlFileContentAndWrite: ptSrcFileContent or pszContentBuffer is NULL!\n"); 
  220.         return; 
  221.     } 
  222.  
  223.     // 根据值的大小对g_szDataStartTime进行赋值 
  224.     if (strlen(g_szDataStartTime) == 0)   // 当天***条 
  225.     { 
  226.         strncpy(g_szDataStartTime, ptSrcFileContent->szDataStartTime, strlen(ptSrcFileContent->szDataStartTime)); 
  227.     } 
  228.     else 
  229.     { 
  230.         if (strncmp(g_szDataStartTime, ptSrcFileContent->szDataStartTime, strlen(ptSrcFileContent->szDataStartTime)) > 0)  // 修改成最小时间 
  231.         { 
  232.             memset(g_szDataStartTime, 0x00, sizeof(g_szDataStartTime)); 
  233.  
  234.             strncpy(g_szDataStartTime, ptSrcFileContent->szDataStartTime, strlen(ptSrcFileContent->szDataStartTime)); 
  235.         } 
  236.     } 
  237.  
  238.     // 根据值的大小对g_szDataEndTime进行赋值 
  239.     if (strlen(g_szDataEndTime) == 0)   // 当天***条 
  240.     { 
  241.         strncpy(g_szDataEndTime, ptSrcFileContent->szDataEndTime, strlen(ptSrcFileContent->szDataEndTime)); 
  242.     } 
  243.     else 
  244.     { 
  245.         if (strncmp(g_szDataEndTime, ptSrcFileContent->szDataEndTime, strlen(ptSrcFileContent->szDataEndTime)) < 0)  // 修改成***时间 
  246.         { 
  247.             memset(g_szDataEndTime, 0x00, sizeof(g_szDataEndTime)); 
  248.  
  249.             strncpy(g_szDataEndTime, ptSrcFileContent->szDataEndTime, strlen(ptSrcFileContent->szDataEndTime)); 
  250.         } 
  251.     } 
  252.  
  253.     // 记录总条数加1 
  254.     g_iRecordsSumg_iRecordsSum = g_iRecordsSum + 1;     // 当天所有记录的总条数加1 
  255.  
  256.     // 打印三个字段的内容 
  257.     printf("GetCtlFileContentAndWrite: DataStartTime is %s, DataEndTime is %s, RecordsSum is %d\n", g_szDataStartTime, g_szDataEndTime, g_iRecordsSum); 
  258.  
  259.     // 组装写到控制文件中的消息内容 
  260.     snprintf(szContentLine, sizeof(szContentLine)-1, "%s|%s|%d|", g_szDataStartTime, g_szDataEndTime, g_iRecordsSum); 
  261.  
  262.     printf("GetCtlFileContentAndWrite: ContentLine is %s\n", szContentLine); 
  263.  
  264.     strncpy(pszContentBuffer, szContentLine, strlen(szContentLine)); 
  265.  
  266.  
  267. /********************************************************************** 
  268. * 功能描述: 获取源文件中的各个字段的值 
  269. * 输入参数: pszContentLine-一条记录 
  270. * 输出参数: ptSrcFileContent-源文件中一条记录中各个字段的值 
  271. * 返 回 值: 无 
  272. * 其它说明: 源文件中每条记录的格式为: SrcNumber|DstNumber|DataStartTime|DataEndTime| 
  273. * 修改日期          版本号       修改人              修改内容 
  274. * ------------------------------------------------------------------ 
  275. * 20151102          V1.0     Zhou Zhaoxiong           创建 
  276. ********************************************************************/ 
  277. void GetSrcFileFieldValue(UINT8 *pszContentLine, T_SrcFileContent *ptSrcFileContent) 
  278.     if (pszContentLine == NULL || ptSrcFileContent == NULL) 
  279.     { 
  280.         printf("GetSrcFileFieldValue: ContentLine or SrcFileContent is NULL!\n"); 
  281.         return; 
  282.     } 
  283.  
  284.     // 获取源号码 
  285.     if (TRUE != GetValueFromStr(1, MML_STR_TYPE, pszContentLine, ptSrcFileContent->szSrcNumber, '|', sizeof(ptSrcFileContent->szSrcNumber))) 
  286.     { 
  287.         printf("GetSrcFileFieldValue: exec GetValueFromStr to get szSrcNumber failed!\n"); 
  288.         return; 
  289.     } 
  290.  
  291.     // 获取目的号码 
  292.     if (TRUE != GetValueFromStr(2, MML_STR_TYPE, pszContentLine, ptSrcFileContent->szDstNumber, '|', sizeof(ptSrcFileContent->szDstNumber))) 
  293.     { 
  294.         printf("GetSrcFileFieldValue: exec GetValueFromStr to get szDstNumber failed!\n"); 
  295.         return; 
  296.     } 
  297.  
  298.     // 获取开始时间 
  299.     if (TRUE != GetValueFromStr(3, MML_STR_TYPE, pszContentLine, ptSrcFileContent->szDataStartTime, '|', sizeof(ptSrcFileContent->szDataStartTime))) 
  300.     { 
  301.         printf("GetSrcFileFieldValue: exec GetValueFromStr to get szDataStartTime failed!\n"); 
  302.         return; 
  303.     } 
  304.  
  305.     // 获取结束时间 
  306.     if (TRUE != GetValueFromStr(4, MML_STR_TYPE, pszContentLine, ptSrcFileContent->szDataEndTime, '|', sizeof(ptSrcFileContent->szDataEndTime))) 
  307.     { 
  308.         printf("GetSrcFileFieldValue: exec GetValueFromStr to get szDataEndTime failed!\n"); 
  309.         return; 
  310.     } 
  311.  
  312.     printf("GetSrcFileFieldValue: SrcNumber=%s, DstNumber=%s, DataStartTime=%s, DataEndTime=%s\n", ptSrcFileContent->szSrcNumber, ptSrcFileContent->szDstNumber,  
  313.                                                                                 ptSrcFileContent->szDataStartTime, ptSrcFileContent->szDataEndTime); 
  314.  
  315.  
  316.  
  317.  
  318. /********************************************************************** 
  319. * 功能描述: 程序休眠 
  320. * 输入参数: iCountMs-休眠时间(单位:ms) 
  321. * 输出参数: 无 
  322. * 返 回 值: 无 
  323. * 其它说明: 无 
  324. * 修改日期          版本号       修改人              修改内容 
  325. * ------------------------------------------------------------------ 
  326. * 20151102          V1.0     Zhou Zhaoxiong           创建 
  327. ********************************************************************/ 
  328. void Sleep(UINT32 iCountMs) 
  329.     struct timeval t_timeout = {0}; 
  330.  
  331.     if (iCountMs < 1000
  332.     { 
  333.         t_timeout.tv_sec = 0
  334.         t_timeout.tv_usec = iCountMs * 1000; 
  335.     } 
  336.     else 
  337.     { 
  338.         t_timeout.tv_sec = iCountMs / 1000; 
  339.         t_timeout.tv_usec = (iCountMs % 1000) * 1000; 
  340.     } 
  341.     select(0, NULL, NULL, NULL, &t_timeout);   // 调用select函数阻塞程序 
  342.  
  343.  
  344. /********************************************************************** 
  345. *功能描述:获取字符串中某一个字段的值 
  346. *输入参数:iSerialNum-字段编号(为正整数) 
  347.            iContentType-需要获取的内容的类型 
  348.            pSourceStr-源字符串 
  349.            pDstStr-目的字符串(提取的值的存放位置) 
  350.            cIsolater-源字符串中字段的分隔符 
  351.            iDstStrSize-目的字符串的长度 
  352. *输出参数:无 
  353. *返 回 值:TRUE-成功  FALSE-失败 
  354. *其它说明:无 
  355. *修改日期        版本号            修改人         修改内容 
  356. * -------------------------------------------------------------- 
  357. * 20151102        V1.0         Zhou Zhaoxiong       创建 
  358. ***********************************************************************/ 
  359. BOOL GetValueFromStr(UINT16 iSerialNum, UINT8 iContentType, UINT8 *pSourceStr, UINT8 *pDstStr, UINT8 cIsolater, UINT32 iDstStrSize) 
  360.     UINT8  *pStrBegin                 = NULL
  361.     UINT8  *pStrEnd                   = NULL
  362.     UINT8   szRetBuf[MAX_RET_BUF_LEN] = {0};     // 截取出的字符串放入该数组中 
  363.     UINT8  *pUINT8                    = NULL
  364.     UINT16 *pUINT16                   = NULL
  365.     UINT32 *pUINT32                   = NULL
  366.     UINT32  iFieldLen                 = 0;      // 用于表示每个字段的实际长度 
  367.  
  368.     if (pSourceStr == NULL)                     // 对输入指针的异常情况进行判断 
  369.     { 
  370.         return FALSE; 
  371.     } 
  372.     //字段首 
  373.     pStrBegin = pSourceStr
  374.     while (--iSerialNum != 0) 
  375.     { 
  376.         pStrBegin = strchr(pStrBegin, cIsolater); 
  377.         if (pStrBegin == NULL) 
  378.         { 
  379.             return FALSE; 
  380.         } 
  381.         pStrBegin ++; 
  382.     } 
  383.  
  384.     //字段尾 
  385.     pStrEnd = strchr(pStrBegin, cIsolater); 
  386.     if (pStrEnd == NULL) 
  387.     { 
  388.         return FALSE; 
  389.     } 
  390.  
  391.     iFieldLen = (UINT16)(pStrEnd - pStrBegin); 
  392.     if(iFieldLen >= MAX_RET_BUF_LEN) //进行异常保护, 防止每个字段的值过长 
  393.     { 
  394.         iFieldLen = MAX_RET_BUF_LEN - 1; 
  395.     } 
  396.  
  397.     memcpy(szRetBuf, pStrBegin, iFieldLen); 
  398.  
  399.     //将需要的字段值放到pDstStr中去 
  400.     switch (iContentType) 
  401.     { 
  402.         case MML_STR_TYPE:                        //字符串类型 
  403.         { 
  404.             strncpy(pDstStr, szRetBuf, iDstStrSize); 
  405.             break; 
  406.         } 
  407.  
  408.         case MML_INT8_TYPE:                       //字符类型 
  409.         { 
  410.             pUINT8   = (UINT8 *)pDstStr; 
  411.             *pDstStr = (UINT8)atoi(szRetBuf); 
  412.             break; 
  413.         } 
  414.  
  415.         case MML_INT16_TYPE:                      // short int类型 
  416.         { 
  417.             pUINT16  = (UINT16 *)pDstStr; 
  418.             *pUINT16 = (UINT16)atoi(szRetBuf); 
  419.             break; 
  420.         } 
  421.  
  422.         case MML_INT32_TYPE:                      // int类型 
  423.         { 
  424.             pUINT32  = (UINT32 *)pDstStr; 
  425.             *pUINT32 = (UINT32)atoi(szRetBuf); 
  426.             break; 
  427.         } 
  428.  
  429.         default:                                  // 一定要有default分支 
  430.         { 
  431.             return FALSE; 
  432.         } 
  433.     } 
  434.  
  435.     return TRUE; 
  436.  
  437.  
  438. /********************************************************************** 
  439. * 功能描述: 去掉字符串后面的回车换行符 
  440. * 输入参数: pszStr-输入的字符串 
  441. * 输出参数: 无 
  442. * 返 回 值: 无 
  443. * 其它说明: 无 
  444. * 修改日期          版本号       修改人              修改内容 
  445. * ------------------------------------------------------------------ 
  446. * 20151102          V1.0     Zhou Zhaoxiong           创建 
  447. ********************************************************************/ 
  448. void RemoveLineEnd(UINT8 *pszStr) 
  449.     UINT32  iStrLen = 0
  450.  
  451.     if (pszStr == NULL) 
  452.     { 
  453.         printf("RemoveLineEnd: pszStr is NULL!\n"); 
  454.         return; 
  455.     } 
  456.  
  457.     iStrLen = strlen(pszStr); 
  458.     while (iStrLen > 0) 
  459.     { 
  460.         if (pszStr[iStrLen-1] == '\n' || pszStr[iStrLen-1] == '\r') 
  461.         { 
  462.             pszStr[iStrLen-1] = '\0'; 
  463.         } 
  464.         else 
  465.         { 
  466.             break; 
  467.         } 
  468.  
  469.         iStrLen --; 
  470.     } 
  471.  
  472.     return; 
  473.  
  474.  
  475. /********************************************************************** 
  476.  * 功能描述: 把内容写到控制文件中 
  477.  * 输入参数: pszContentLine-一条文件记录 
  478.  * 输出参数: 无 
  479.  * 返 回 值: 无 
  480.  * 其它说明: 无 
  481.  * 修改日期        版本号     修改人            修改内容 
  482.  * ------------------------------------------------------ 
  483.  * 20151103        V1.0     Zhou Zhaoxiong       创建 
  484.  ***********************************************************************/ 
  485. void WriteToCtlFile(UINT8 *pszContentLine) 
  486.     FILE  *fpCtlFile = NULL
  487.  
  488.     if (pszContentLine == NULL) 
  489.     { 
  490.         printf("WriteToCtlFile: pszContentLine is NULL.\n"); 
  491.         return; 
  492.     } 
  493.  
  494.     fpCtlFile = fopen(g_szCtlFileName, "w"); 
  495.     if (fpCtlFile != NULL) 
  496.     { 
  497.         fputs(pszContentLine, fpCtlFile); 
  498.         fclose(fpCtlFile); 
  499.         fpCtlFile = NULL
  500.  
  501.         printf("WriteToCtlFile: write ctl file successfully! file=%s, content=%s\n", g_szCtlFileName, pszContentLine); 
  502.     } 
  503.     else 
  504.     { 
  505.         printf("WriteToCtlFile: write ctl file failed! file=%s, content=%s\n", g_szCtlFileName, pszContentLine); 
  506.     } 

程序编译及运行

将程序代码上传到Linux机器上,并在当前用户的zhouzhaoxiong/zzx/CtlFileCreate/SrcFile目录下上传一些满足命名规范的源文件,然后使用“gcc -g -o CtlFileCreate main.c CtlFileCreate.c”命令对程序进行编译,生成“CtlFileCreate”文件;接着运行“CtlFileCreate”命令,可以看到在当前用户的zhouzhaoxiong/zzx/CtlFileCreate/CtlFile目录下有控制文件生成,在当前用户的zhouzhaoxiong/zzx/CtlFileCreate/SrcFile_bak目录下有源文件的备份文件生成。

查看控制文件内容,里面记录的就是当前所处理的所有文件中的记录总条数及所有记录中的呼叫起始时间最小值和呼叫结束时间***值。

程序说明

***,为了便于说明,在本程序中,源文件的前缀是“Test_”,控制文件命名为“CtlFile.txt”。在实际的开发中,大家完全可以通过配置项来决定源文件及控制文件的命名规则。

第二,为了防止源文件被重复处理,当某个源文件处理完成之后,会被剪切到备份目录中。这样做也是为了方便之后校对控制文件中的内容。

第三,在读取文件中的***条记录时,将该条记录中的呼叫起始时间和呼叫结束时间分别存放到两个全局变量中,并按照格式写控制文件;在读取该文件中的其他记录时,首先将该条记录中的呼叫起始时间和呼叫结束时间与全局变量进行比较,确保全局变量中存放的是呼叫起始时间最小值和呼叫结束时间***值,记录总条数加1,并将新的记录内容写入到控制文件中。

第四,在处理完当前目录下的所有文件之后,程序会休眠一段时间,然后继续扫描目录。在实际的开发中,休眠间隔也是可以配置的。

(本文中的部分代码已经提交到GitHub上,欢迎下载阅读:

https://github.com/zhouzxi/CtlFileCreate)

【本文是51CTO专栏作者周兆熊的原创文章,作者微信公众号:周氏逻辑(logiczhou)】

戳这里,看该作者更多好文

责任编辑:赵宁宁 来源: 51CTO专栏
相关推荐

2009-08-18 13:35:06

C#枚举文件

2011-01-19 15:03:24

Qmail控制文件

2009-04-03 10:25:32

C#XML扩展代码

2009-08-12 18:29:06

C#读取TXT文件

2011-03-04 09:40:36

Vsftpd文件

2012-09-21 10:30:56

Linux项目代码覆盖率

2011-03-04 10:04:31

Linux文件操作命令

2015-11-11 15:19:13

Linux编译调试

2009-06-26 10:43:57

生成EXCELJSF

2010-10-29 14:20:54

Oracle移动控制文

2010-06-04 10:49:58

Linux流量控制

2010-08-02 14:29:46

LinuxPingICMP

2012-09-19 10:14:12

Visual Stud

2014-01-22 11:04:51

Linux流量监控

2009-09-02 17:24:44

C#关机代码

2024-03-06 08:52:59

C#Emit代码

2011-01-19 09:57:48

Postfix控制

2024-01-07 16:42:32

C++编程开发

2023-09-04 11:46:09

C#动态代码

2010-05-28 11:05:56

Linux下dhcp测
点赞
收藏

51CTO技术栈公众号