C语言的问题关于从文本文件读取数据到链表。。。。
文本文件dict.txt的格式如图,我写了段代码,但是运行后发现单词的首字母都没有办法存到链表中去,是哪里的问题啊怎么改。。。#include<stdio.h>#incl...
文本文件dict.txt的格式如图,我写了段代码,但是运行后发现单词的首字母都没有办法存到链表中去,是哪里的问题啊 怎么改。。。
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 10000
struct dictionary
{
char word[51];
char mean[1025];
struct dictionary *next;
}dict[N];
void load()
{
FILE *fp;
if((fp=fopen("dict.txt","r"))==NULL)
{
printf("cannot open file\n");
exit(0);
}
int i;
for(i=0;fgetc(fp)!=EOF;i++)
{
fscanf(fp,"%50[^\n]",dict[i].word);
fgetc(fp);
fscanf(fp,"%1025[^\n]",dict[i].mean);
fgetc(fp);
printf("%s\n",dict[i].word);
printf("%s\n",dict[i].mean);
}
fclose(fp);
}
void main()
{
load();
} 展开
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 10000
struct dictionary
{
char word[51];
char mean[1025];
struct dictionary *next;
}dict[N];
void load()
{
FILE *fp;
if((fp=fopen("dict.txt","r"))==NULL)
{
printf("cannot open file\n");
exit(0);
}
int i;
for(i=0;fgetc(fp)!=EOF;i++)
{
fscanf(fp,"%50[^\n]",dict[i].word);
fgetc(fp);
fscanf(fp,"%1025[^\n]",dict[i].mean);
fgetc(fp);
printf("%s\n",dict[i].word);
printf("%s\n",dict[i].mean);
}
fclose(fp);
}
void main()
{
load();
} 展开
2个回答
展开全部
问题其实很简单。
void load()
{
FILE *fp;
if((fp=fopen("dict.txt","r"))==NULL)//如果文件存在,那么正常打开后fp指针指在文件的开头,即指向第一个字节处
{
printf("cannot open file\n");
exit(0);
}
int i;
for(i=0;fgetc(fp)!=EOF;i++)//调用fgetc(fp)会返回一个字符同时fp加1指向文件中的下一个字符,所以下面读每个单词时第一个单词的首字母被漏掉。
{
fscanf(fp,"%50[^\n]",dict[i].word);//最多读50个字符直到遇到\n为止
fgetc(fp);
fscanf(fp,"%1025[^\n]",dict[i].mean);
fgetc(fp);
printf("%s\n",dict[i].word);
printf("%s\n",dict[i].mean);
}
fclose(fp);
}
--------------------------------------------------------------------
要改动很简单。小可以为你的方法一般,在你的基础上改比较繁琐,下面给出我的方法。
void load()
{
FILE *fp;
if((fp=fopen("dict.txt","r"))==NULL)
{
printf("cannot open file\n");
exit(0);
}
int i;
while(fgets(dict[i].word,50,fp)!=NULL)//字符串函数fgets()特别适合按行读文本文件,这里最多读入50-1个字符,如果提前遇到\n,读入\n后读入一行结束
{
while(fgets(dict[i].mean,1025,fp)!=NULL)
{
printf("%s",dict[i].word);//去掉最后的换行符号,因为fgets()会把每行最后的换行符号也读入
printf("%s",dict[i].mean);
i++;
}
}
fclose(fp);
}
void load()
{
FILE *fp;
if((fp=fopen("dict.txt","r"))==NULL)//如果文件存在,那么正常打开后fp指针指在文件的开头,即指向第一个字节处
{
printf("cannot open file\n");
exit(0);
}
int i;
for(i=0;fgetc(fp)!=EOF;i++)//调用fgetc(fp)会返回一个字符同时fp加1指向文件中的下一个字符,所以下面读每个单词时第一个单词的首字母被漏掉。
{
fscanf(fp,"%50[^\n]",dict[i].word);//最多读50个字符直到遇到\n为止
fgetc(fp);
fscanf(fp,"%1025[^\n]",dict[i].mean);
fgetc(fp);
printf("%s\n",dict[i].word);
printf("%s\n",dict[i].mean);
}
fclose(fp);
}
--------------------------------------------------------------------
要改动很简单。小可以为你的方法一般,在你的基础上改比较繁琐,下面给出我的方法。
void load()
{
FILE *fp;
if((fp=fopen("dict.txt","r"))==NULL)
{
printf("cannot open file\n");
exit(0);
}
int i;
while(fgets(dict[i].word,50,fp)!=NULL)//字符串函数fgets()特别适合按行读文本文件,这里最多读入50-1个字符,如果提前遇到\n,读入\n后读入一行结束
{
while(fgets(dict[i].mean,1025,fp)!=NULL)
{
printf("%s",dict[i].word);//去掉最后的换行符号,因为fgets()会把每行最后的换行符号也读入
printf("%s",dict[i].mean);
i++;
}
}
fclose(fp);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
for(i=0;fscanf(fp,"%50[^\n]\n",dict[i].word)!=EOF;i++)
{
fscanf(fp,"%1025[^\n]\n",dict[i].mean);
printf("%s\n",dict[i].word);
printf("%s\n",dict[i].mean);
}
How about this one?
Have a try.
{
fscanf(fp,"%1025[^\n]\n",dict[i].mean);
printf("%s\n",dict[i].word);
printf("%s\n",dict[i].mean);
}
How about this one?
Have a try.
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询