C语言提取文件内容保存到字符串数组问题

我想吧一个txt文件内的单词用c语言提取出来,存到一个str字符串数组里,然后通过遍历可以降数组里的数据打印出来。代码如下#include<stdio.h>#includ... 我想吧一个txt文件内的单词用c语言提取出来,存到一个str字符串数组里,然后通过遍历可以降数组里的数据打印出来。

代码如下

#include <stdio.h>
#include <string.h>
#define PATH "/Users/SQZS/Desktop/word.txt"
FILE *fp;
int i = 0;
char word[1024],str[1024];
int main()
{
fp = fopen(PATH,"rw+");
if (fp == NULL)
{
/* code */
printf("error\n");
}
else
{
while((fgets(&str[i],100,fp) != NULL))
{
printf("%s\n",str );
i++;
}
printf("%c",str[0]);
}
}

但是运行后,结果有乱码。
结果如下(为了测试,只有2个单词)

するめ鯣
\343あまざけ
\343

那个\343是什么东西。怎么来的呢。
展开
 我来答
cdyzxy
推荐于2016-07-26 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.4万
采纳率:85%
帮助的人:3764万
展开全部
你的程序的问题:
1.文件如果不是要读同时又要写的情况,用'r'属性打开就可以了;
你的程序最后没有关闭文件。
2.while((fgets(&str[i],100,fp) != NULL))应该写成while((fgets(str,100,fp) != NULL))
原因:fgets是读取文件中的一整行数据放到第一个参数位置,
你第一行装入str+0位置,第二行放到str+1??这个没有道理呀,何况你下面还
用str[0]来打印输出。
3.我读你程序,似乎是要将文件中的所有单词全部读出,而且文件中每个单词占用一行,
象程序中的定义,你所有单词的字符串的字符个数不能超过1024个。
如果要将小于1024个单词读出来,需要统计一下最长单词的字符个数,比如我们假定是9,
那么我们程序中就可以定义数组了(每行单词字符加换行符加字符串结尾符有时还有回车符):
char world[1024][12],str[1024][12];
每次用fgets(str[i],10,fp)读进来,i可以从0开始,每单词加1,程序可以象下面设计:
#include "stdio.h"
#include "string.h"
#define PATH "/Users/SQZS/Desktop/word.txt"
main()
{
FILE *fp;
char world[1024][12],str[1024][12];
int i,nNumber;
i=nNumber=0;
if ( fp=fopen(PATH,"r") )
{
fgets(str[i],12,fp);
while ( !feof(fp) )
{
nNumber++; i++;
fgets(str[i],12,fp);
}
fclose(fp);
for ( i=0;i<nNumber;i++ ) printf("%s",str[i]);
}
else printf("不能打开文本文件'%s'.\n",PATH);
}
tattackor
2015-10-31 · TA获得超过3.5万个赞
知道大有可为答主
回答量:5083
采纳率:94%
帮助的人:895万
展开全部

使用文件操作函数即可。

1、fgets函数:
原型:char * fgets(char * buf, int bufsize, FILE * stream);
功能:从文件结构体指针stream中读取数据,每次读取一行;
说明:读取的数据保存在buf指向的字符数组中,每次最多读取bufsize-1个字符(第bufsize个字符赋值为\0)。如果该行不足bufsize个字符,则读完该行就结束,如果该行超过bufsize-1个字符,则fgets只返回一个不完整的行,buf缓冲区以\0字符结束,下一次fgets调用会继续读取该行剩余的字符;
头文件:stdio.h;
返回值:若读入成功,返回与参数buf相同的字符指针,若读入过程中遇到EOF或发生错误,返回NULL指针。所以当遇到返回值为NULL的情况时,应使用ferror或feof函数检查是发生错误还是遇到EOF。
2、例程:

#include<stdio.h>
int a;
char b,c[100];
int main(){
    FILE * fp1 = fopen("input.txt", "r");//打开输入文件
    FILE * fp2 = fopen("output.txt", "w");//打开输出文件
    if (fp1==NULL || fp2==NULL) {//若打开文件失败则退出
        puts("不能打开文件!");
        return 0;
    }
    fscanf(fp1,"%d",&a);//从输入文件读取一个整数
    b=fgetc(fp1);//从输入文件读取一个字符
    fgets(c,100,fp1);//从输入文件读取一行字符串
    
    printf("%ld",ftell(fp1));//输出fp1指针当前位置相对于文件首的偏移字节数
    
    fputs(c,fp2);//向输出文件写入一行字符串
    fputc(b,fp2);//向输出文件写入一个字符
    fprintf(fp2,"%d",a);//向输出文件写入一个整数
    
    fclose(fp1);//关闭输入文件
    fclose(fp2);//关闭输出文件,相当于保存
    return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友b24d08f
2013-01-28 · TA获得超过114个赞
知道小有建树答主
回答量:114
采纳率:0%
帮助的人:81.6万
展开全部
楼主的应该是日语单词,是宽字符,而char只可以处理单字符,建议楼主使用wchar_t以及配套的输入输出函数。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
千江月success
2013-01-28 · TA获得超过827个赞
知道小有建树答主
回答量:1031
采纳率:100%
帮助的人:915万
展开全部
你的单词是中文还是英文,中文应该是不可以。。
英文测试无误

#include <stdio.h>
#include <string.h>
#define PATH "word.txt"
FILE *fp;
int i = 0;
char word[1024],str[1024];
int main()
{
fp = fopen(PATH,"r");
if (fp == NULL)
{
/* code */
printf("error\n");
}
else
{
while((fgets(&str[i],100,fp) != NULL))
{
printf("%s\n",str );
i++;
}
printf("%c",str[0]);
}
}

----------------------------------
1、文件打开方式用r,我这显示rw+是错的..没弄明白
2、PATH路径应该得用\\吧,我怕麻烦直接相对路径,将word.txt放在工程路径下
----------------
调试无误。。。
更多追问追答
追问
换成英文单词以后,如下
admin
bad
2个单词。
printf("%s",str[1]);出错
printf("%c",str[1]);只输出一个b。
追答
printf("%s",str[1]);出错
printf("%c",str[1]);只输出一个b。
%s是字符串,你用str[1]当然出错
%c是字符,你只能输出一个字符了。
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式