我正在使用带有两个字段的fscanf读取CSV文件。
datatype_t*read(FILE* fp)
{
char name[66];
char data[1466];
if (fscanf(fp, "%[^,] %[^\n]", name, data) == 2) {
datatype_t *d = (datatype_t*)malloc(sizeof(datatype_t));
d->name = strdup(name);
d->data = strdup(data);
return d;
}
return NULL;
}
CSV文件数据如下
戴夫先生,学校老师 迈克,头现在我正在阅读另一个包含数据的文本文件。
char buffer[66];
if (fgets(buffer,sizeof buffer, fp) != NULL ) {
keydata_t *k = (keydata_t*)malloc(sizeof(keydata_t));
size_t len = strlen(buffer);
if(buffer > 0 && buffer[len-1] == '\n'){
buffer[--len] = '\0';
}
k->name = strdup(buffer);
return k;
}
return NULL;
}
txt文件的数据如下所示。
戴夫先生
罗恩
蒂姆先生
现在当我比较数据字符串时:
new_ptr = root;
while((keyt = read_key(keyfile))!= NULL){
printf("%s\n", keyt->name);
printf("%s\n", root->key);
if(strcmp(keyt->name, root->key) == 0){
printf("match\n");
}
else if(strcmp(keyt->name, root->key) > 0){
printf("not equal\n");
}
else if (strcmp(keyt->name, root->key) < 0){
printf("not equal\n");
}
new_ptr = search(new_ptr, keyt);
}
它保持印刷不等于
即使戴夫先生应该有一场比赛。我似乎无法弄清楚这两个问题。
答案 0 :(得分:2)
来自man fgets
:
fgets
从流中读取最多一个小于大小的字符,并将它们存储到s指向的缓冲区中。读数在EOF或换行符后停止。如果读取换行符,则将其存储到缓冲区中。终止空字节(aq \ 0aq)存储在缓冲区中的最后一个字符之后。
fscanf
不将换行符存储在缓冲区中。
请尝试检查keyt->name
的最后一个符号是什么,如果是换行符,请将其删除
答案 1 :(得分:0)
首先,您应该打印要比较的字符串的每个字符作为十六进制/十进制值。字符串可能包含在控制台中打印的字符,但您无法看到它们。可见输出看起来可能相同,但仍然可能不同。打印(例如)十六进制值将准确显示字符串内部的内容。
然后,如果两个字符串的输出相同,并且strcmp仍然会返回0以外的其他内容,你应该担心(但我相信它不会是:)