我有 2 个问题,第一个是,我无法让我的行在我的阵列的打印中匹配。我只能得到第一行来匹配!
void printStructs(struct student *list, int size){
int j = 0;
printf("Last Name, First Name Term ID Course Section\n");
printf("-------------------------------- ---- --------- ------ -------\n");
while(j < size){
printf("%s, %-21s %-5d %-11d %s%d %7s\n", list[j].lastname, list[j].firstname, list[j].term, list[j].id, list[j].subjectname,list[j].catalog, list[j].section);
j++;
}
}
这为我提供了这个的输出!
看看只有第一个是如何正确排列的?我如何让剩余的行来做到这一点!?
现在我的第二个问题是我根本看不到的问题。注意到在显示姓氏之前的倒数第二行中多余的“Susan”吗?这是哪里来的!?它适用于所有其他名称,我在这里没有看到什么?
编辑:在这里找不到涉及额外名称的错误!刚刚意识到这与我将名称初始化为该值的循环有关,如果我无法弄清楚,将进一步编辑,现在忽略!
EDIT2“额外字符串问题!”:
好吧,所以我已经缩小了问题所在,但不完全是它发生的原因,我相信它与分隔符有关......这是代码
studentsRead = readStudentList(inputf, students, N);
printf("%s\n", students[6].lastname);
printStructs(students, studentsRead);
/*for (j = 1 ; j <= 10-1 ; j++){
for(k = 0 ; k <= 10-2 ; k++){
if(students[k] > students[k+1]){
temp = students[k];
students[k] = students[k+1];
students[k+1] = temp;
}
}
}*/
fclose(inputf);
return 0;
}
int readStudentList(FILE *f, struct student *list, int maxSize){
char buff[65];
int count = 0;
while((count < maxSize) && (fgets(buff, sizeof(buff), f) != NULL)){
struct student item;
if(parseStudent(&item, buff)){
list[count++] = item;
}
}
return count;
}
int parseStudent(struct student *person, char *data){
char *ptr;
int i = 0;
ptr = strtok(data, DELIM);
person[i].term = atoi(ptr);
ptr = strtok(NULL, DELIM);
person[i].id = atoi(ptr);
ptr = strtok(NULL, DELIM);
strcpy(person[i].lastname, ptr);
printf("%s\n", person[i].lastname);
ptr = strtok(NULL, DELIM);
strcpy(person[i].firstname, ptr);
ptr = strtok(NULL, DELIM);
strcpy(person[i].subjectname, ptr);
ptr = strtok(NULL, DELIM);
person[i].catalog = atoi(ptr);
ptr = strtok(NULL, DELIM);
strcpy(person[i].section, ptr);
}
通过这段代码,一切正常打印,直到我的 readStudentList 调用之后的 printf ,它打印出姓氏,名字 String 卡在最后。尽管在我的解析函数中打印了姓氏似乎正常显示?我一直在尝试将打印输出放在整个地方,看看哪里出了问题,但其中一些甚至不会打印任何东西?