- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试用 C 创建一个从文件中读取输入的程序,让它成为 Input.inp
,其中包含带有空格和制表符分隔的单词的字符串,可能是多个,然后写入文件 Output.out
,每个单词占一行。例如,输入文件包含
Hi my name is Yang
那么输出文件将如下所示
Hi
my
name
is
Yang
此外,如果程序到达文件末尾或到达“#”,程序将停止读取。
下面是我的代码。我从文件中获取字符,然后检查它是否是“#”或文件结尾。如果不是,它将检查该字符是否是空格、制表符或行尾。如果不是,则该字符将被放入字符串“word”中。现在,如果我们到达空格、制表符或行尾,那么我将打印字符串“word”,将 pos 设置回 0 并继续执行此操作。但这行不通。有人可以解释为什么我的代码失败并为我提供如何解决此问题的指导吗?
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define maxn 300
int main(){
FILE *fin, *fout;
fin = fopen("splitwords.inp", "r");
fout = fopen("splitwords.txt", "w");
char buffer[maxn], word[maxn], ch, d;
int i, pos = 0;
while((ch = fgetc(fin)) != EOF && ch != '#'){
while(ch != ' ' && ch != '\t' && ch != '\0'){
word[pos] = ch;
pos++;
if((d = fgetc(fin)) == ' ' || d == '\t' || d == '\0'){
word[pos] = '\0';
fputs(word, fout);
printf("%s", word);
pos = 0;
}
}
if(ch == ' ' || ch == '\t' || ch == '\0') continue;
}
fclose(fin);
fclose(fout);
}
最佳答案
关于您的提案的一些评论
正如评论中所说,当您读取一个字符时,使用 int 来保存它,而不是 char,您的编译器可能会发出警告在 while((ch = fgetc(fin)) != EOF
上发出问题信号,例如 由于数据类型范围有限,比较始终为真,这是因为 EOF 无法保存在 char 中。因此,在您的代码中,ch 和 d 必须是 int>
检查fopen的结果以确保您打开了文件。
最好添加( )以避免运算符之间可能出现的优先级问题,因此替换
while((ch = fgetc(fin)) != EOF && ch != '#')
while(ch != ' ' && ch != '\t' && ch != '\0'){
if((d = fgetc(fin)) == ' ' || d == '\t' || d == '\0'){
if(ch == ' ' || ch == '\t' || ch == '\0')
by(不考虑其他可能的问题)
while(((ch = fgetc(fin)) != EOF) && (ch != '#'))
while((ch != ' ') && (ch != '\t') && (ch != '\0')){
if(((d = fgetc(fin)) == ' ') || (d == '\t') || (d == '\0')){
if((ch == ' ') || (ch == '\t') || (ch == '\0'))
正如评论中所说,如果您输入这两个 while :
while((ch = fgetc(fin)) != EOF && ch != '#'){
while(ch != ' ' && ch != '\t' && ch != '\0'){
你将永远无法出去,因为ch内部没有改变,所以你在word中写了越来越多的东西,最后以未定义的行为离开了它(通常是崩溃)。
您不需要检查空字符的大小写,它不存在于文本文件中。
您错过了管理换行符的大小写('\n' 和 '\r')
独立于问题,因为ch不变,你从不检查读取的单词是否足够长而无法放入单词,你不能认为它在任何情况下都会。
在
if((d = fgetc(fin)) == ' ' || d == '\t' || d == '\0'){
您错过了管理换行符的大小写,并且不必管理空字符的大小写。
线路
if(ch == ' ' || ch == '\t' || ch == '\0') continue;
没用,它位于 while block 的末尾,所以即使没有它,你也会重新循环
<小时/>create a program in C that read inputs from a file, let it be Input.inp that contains strings with words that is separated with spaces and tabs, possibly multiple and then write to a file Output.out, with each word on a line.
你的程序也太复杂了,你不需要将单词保存在内存中(这也有能够管理超过299个单词的优点),你的目标是将每个单词放在输出中的单独行上文件,所以一个简单的解决方案是:
#include <stdio.h>
int main()
{
FILE *fin, *fout;
if ((fin = fopen("splitwords.inp", "r")) == NULL)
puts("cannot open splitwords.inp");
else {
if ((fout = fopen("splitwords.txt", "w")) == NULL)
puts("cannot open splitwords.txt");
else {
int word = 0; /* not inside a word */
int c; /* an int to manage EOF */
while (((c = fgetc(fin)) != EOF) && (c != '#')) {
if ((c == ' ') || (c == '\t') ||
(c == '\n') || (c == '\r')) { /* can use isspace() */
if (word) {
/* the space finishes a word, add the new line */
fputc('\n', fout);
word = 0; /* not in a word now */
}
}
else {
fputc(c, fout); /* char of word are placed in output file */
word = 1; /* we are in a word */
}
}
if (word) {
/* we was reading a word, need to add the final newline */
fputc('\n', fout);
}
fclose(fout);
}
fclose(fin);
}
}
编译和执行:
/tmp % gcc -pedantic -Wextra f.c
/tmp % cat splitwords.inp
Hi my name is Yang
/tmp % ./a.out
/tmp % cat splitwords.txt
Hi
my
name
is
Yang
一些解释和评论:
上面的代码只是在输出文件中写入非空格/制表符/换行符,更多的是它只需要检测单词的结尾来添加换行符,这是我的变量 word 的目标 当先前管理的字符不是空格/制表符/换行符时值为 1,否则为 0
关于c - 从字符串中提取单词(单词之间用空格和制表符分隔,可能是多个),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55046239/
我正在做一个业余爱好项目,使用 Ruby、PHP 或 Java 来抓取 ASP.net 网站的内容。例如,如果网站 url“www.myaspnet.com/home.aspx”。我想从 home.a
如果我有这些字符串: mystrings <- c("X2/D2/F4", "X10/D9/F4", "X3/D22/F4",
我有以下数据集 > head(names$SAMPLE_ID) [1] "Bacteria|Proteobacteria|Gammaproteobacteria|Pseudomonadales|Mor
设置: 3个域类A,B和C。A和B在插件中。 C在依赖于此插件的应用程序中。 class A{ B b static mapping = { b fetch: 'joi
我不知道如何提取 XML 文件中的开始标记元素名称。我很接近〜意味着没有错误,我正在获取标签名称,但我正在获取标签名称加上信息。我得到的是: {http://www.publishing.org}au
我有一个字符串 x <- "Name of the Student? Michael Sneider" 我想从中提取“Michael Sneider”。 我用过: str_extract_all(x,
我有一个如下所示的文本文件: [* content I want *] [ more content ] 我想读取该文件并能够提取我想要的内容。我能做的最好的事情如下,但它会返回 [更多内容] 请注意
假设我有一个项目集合 $collection = array( 'item1' => array( 'post' => $post, 'ca
我正在寻找一种过滤文本文件的方法。我有许多文件夹名称,其中包含许多文本文件,文本文件有几个没有人员,每个人员有 10 个群集/组(我在这里只显示了 3 个)。但是每个组/簇可能包含几个原语(我在这里展
我已经编写了一个从某个网页中提取网址的代码,我面临的问题是它不会以网页上相同的方式提取网址,我的意思是如果该网址位于某些网页中法语,它不会按原样提取它。我该如何解决这个问题? import reque
如何在 C# 中提取 ZipFile?(ZipFile 是包含文件和目录) 最佳答案 为此使用工具。类似于 SharpZip .据我所知 - .NET 不支持开箱即用的 ZIP 文件。 来自 here
我有一个表达: [training_width]:lofmimics 我要提取[]之间的内容,在上面的例子中我要 training_width 我试过以下方法: QRegularExpression
我正在尝试创建一个 Bash 脚本,该脚本将从命令行给出的最后一个参数提取到一个变量中以供其他地方使用。这是我正在处理的脚本: #!/bin/bash # compact - archive and
我正在寻找一个 JavaScript 函数/正则表达式来从 URI 中提取 *.com...(在客户端完成) 它应该适用于以下情况: siphone.com = siphone.com qwr.sip
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
编辑:添加了实际的 JSON 对象和代码以供审查 我有这种格式的 JSON(只是这种层次结构,假设 JSON 正常工作) {u'kind': u'calendar#events', u'default
我已经编写了代码来使用 BeautifulSoup 提取一本书的 url 和标题来自页面。 但它并没有在 > 之间提取惊人的 super 科学故事 1930 年 4 月这本书的名字。和 标签。 如何提
使用 Java,我想提取美元符号 $ 之间的单词。 例如: String = " this is first attribute $color$. this is the second attribu
您好,我正在尝试找到一种方法来确定字符串中的常量,然后提取该常量左侧的一定数量的字符。 例如-我有一个 .txt 文件,在那个文件的某处有数字 00nnn 数字的例子是 00234 00765 ...
php读取zip文件(删除文件,提取文件,增加文件)实例 从zip压缩文件中提取文件 复制代码 代码如下: <?php /* php 从zip压缩文件
我是一名优秀的程序员,十分优秀!