将不需要的数据保存到错误文件中

时间:2014-12-14 00:25:22

标签: c function pointers if-statement struct

您好我目前有一段代码可以从文件中获取名称,然后将其保存到另一个文件中。

但是我现在想将任何无效信息保存到一个固定的错误文件中,并且想知道我是怎么做的

我的代码:

STRUCT:

struct Person{
    char fName[16];     //string to store the persons first name
    char lName[21];     //string to store the persons last name
};

主要

int main(){
    int recordCount = 0;    //used to keep track of the number of records currently in memory
    struct Person *records;

    records = malloc(sizeof(struct Person));

    records = open(&recordCount, records);
    records = addRecord(&recordCount, records);
    save(recordCount, records);
    return 0;                   //End the program and return 0 to the operating system
}

打开(& recordCount,records)功能:

struct Person* open(int *rCount, struct Person *records){
  FILE *recordFile;
  char fileName[30] = {'\0'};
  int i = *rCount;
  char test;


  puts("Enter a filename to open :");
  scanf("%s", fileName);

  if((recordFile = fopen(fileName,"r"))==NULL){
      printf("Couldn't open the file: %s\n",fileName);
      exit(1);
  }
  else{

      test = fscanf(recordFile,"%s %s", records[i].fName,records[i].lName);
      while(test!= EOF){
          i++;
          records = realloc(records,(i+1)*sizeof(struct Person));
          test = fscanf(recordFile,"%s %s", records[i].fName,records[i].lName);
      }
      fclose(recordFile); // close the file
  }
  *rCount = i;
  return records;    //add i (records read from the file) to rCount (the current record count)
}

addRecord(& recordCount,records)function

struct Person* addRecord(int* rCount, struct Person *records){

int valid = 0;  //used to indicated valid input
int length = 0; //used to store the string lengths
int i = 0;    //used in the for loops
char fNameTest[16];     //temporary storage of input to be checked before adding to records
char lNameTest[21];     //temporary storage of input to be checked before adding to records

//Checking the length of data input for fName
do{
    length = strlen(fNameTest);
    if(length < 16){
        for(i=0;i<=length;i++)                      
            records[*rCount].fName[i] = fNameTest[i]; //if correct insert the record at the index determined by rCount
        valid=1;
    }
    else{

        valid = 0;
    }

}while(valid!=1);

//Checking the length of data input for lName
do{
    length = strlen(lNameTest);
    if(length < 21){
        for(i=0;i<=length;i++)                    
            records[*rCount].lName[i] = lNameTest[i]; //if correct insert the record at the index determined by rCount
        valid=1;
        (*rCount)++;                                   //At this point ID,fName and lName have been stored so increment rCount
    }
    else{

        valid = 0;
    }

}while(valid!=1);


records = realloc(records,((*rCount)+1)*sizeof(struct Person));
return records;  //return rCount as the new updated recordCount
}

保存(recordCount,记录)功能

void save(int rCount, struct Person *records){
  FILE *recordFile;                 //file handle
  char fileName[30] = { '\0'};      //string to store the file name
  int i;

  puts("Enter a filename to save the records :");   //ask the user for the filename
  scanf("%s", fileName);                            //store the filename: data input should be checked
                                                    //here in your program

  //try and open the file for writing and react accordingly if there is a problem
  if((recordFile = fopen(fileName,"w"))==NULL){
      printf("Couldn't open the file: %s\n",fileName);
  }
  else{ //the file opened so print the records array of Person's to it
      for(i=0;i<rCount;i++){
          fprintf(recordFile,"%s %s\n",records[i].fName,records[i].lName);
      }
      fclose(recordFile);   //close the file
      printf("Records saved to file: %s\n",fileName);
  }

}

我在考虑删除addRecords函数中的do-while循环并用if语句替换它们。然后最后用if语句来检查有效值。然后如果valid = 0指向一个函数或直接保存错误文件。

但是我不确定这是否是最好的方式(或者如果我的思维过程甚至可以工作)并且想知道是否有人可以提供帮助。

编辑:决定添加我正在处理的数据类型,如果有人想要创建.txt并运行程序

Bob Jones
Franklin Davies
James Donut

编辑按照以下答案,我更新了我的代码(下面编辑过的片段)

EDITED saveFunction

void save(int rCount, struct Person *records){
  FILE *recordFile;                 //file handle
  char fileName[30] = { '\0'};      //string to store the file name
  int i;

  puts("Enter a filename to save the records :");   //ask the user for the filename
  scanf("%s", fileName);                            //store the filename: data input should be checked
                                                    //here in your program

  //try and open the file for writing and react accordingly if there is a problem
  if((recordFile = fopen(fileName,"w"))==NULL){
      printf("Couldn't open the file: %s\n",fileName);
  }
  else{ //the file opened so print the records array of Person's to it

char fileName[sizeof (struct Person) * 2];  // twice needed size

while (fgets(fileName, sizeof fileName, recordFile) != NULL) {
struct Person P;

int n;  // Save index where scanning stopped
int cnt = sscanf(fileName,"%15s%21s %n", P.fName, P.lName, &n);
if (cnt != 2 || fileName[n]) {
  errorLine(fileName);
  // do not increment i;
} else {
  // Good to keep
  // realloc memory as needed here
  records[i] = P;
  i++;
  }

}

errorLine函数:

void errorLine(char *fileName)
{
FILE *errorFile;

  //try and open the file for writing and react accordingly if there is a problem
  if((errorFile = fopen("error.txt","w"))==NULL){
      printf("Couldn't open the file:\n");
  }
  else{ //the file opened so print the records array of Person's to it
      for(i=0;i<rCount;i++){
          fprintf(errorFile,"%i %s %s\n",records[i].fName,records[i].lName);
      }
      fclose(errorFile);   //close the file
      printf("Records saved to file: %s\n",fileName);
  }
}

毫无疑问,我可能错误地实现了答案,现在出现错误:

error: expected declaration or statement at end of input

我在程序的最后一行找到了

1 个答案:

答案 0 :(得分:0)

在尝试保存在结构中之前,需要限制输入的长度。

else {
  char buffer[sizeof (struct Person) * 2];  // twice needed size
  while (fgets(buffer, sizeof buffer, recordFile) != NULL) {
    struct Person P;

    int n;  // Save index where scanning stopped
    int cnt = sscanf(buffer,"%15s%21s %n", P.fName, P.lName, &n);
    if (cnt != 2 || buffer[n] || MaybeAddtionalTests(&P)) {
      SaveBadLine(buffer);
      // do not increment i;
    } else {
      // Good to keep
      // realloc memory as needed here
      records[i] = P;
      i++;
    }
  }
  fclose(recordFile); // close the file