- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 C 中的 sscanf 解析标准输入流中的数字
我有一个文本文件,其中包含以字母开头的行,然后是无符号整数(有时是一对,有时只是一个)。每行的开头都有一个字母用于对该行进行分类。 (见下文)我能够获取文件的内容并将其读取到屏幕上。但是,我正在努力使用 sscanf 从每行中提取字母和每个整数。因此,结果将是 char、int 和 int,全部位于单独的变量中 - 仅以“a”行为例。我一直在使用下面的代码。我得到的最好的结果是 sscanf 会导致全零的奇怪行为。再次,我试图将 char 和每个 int 放入单独的变量中。
文本文件中的行示例
a -1109180 699692587
a 1213834231 -226769626
c 994957275 2082945813
e 1213834231
//The Code Used//////////////
char *line = NULL;
size_t size;
int results;
int val1;
int val2;
while (getline(&line, &size, stdin) != -1){
if(strstr(line,"a") != NULL){
sscanf(line,"Val1 and Val2: %d %d", val1,val2);
printf("Value1 %d\n",val1);
printf("Value2 %d\n",val2);
}
//This prints each line in file
printf("%s\n", line);
}
有点不知道这里缺少什么。 sscanf 是在 C 中实现此目的的最佳方法还是有更简单的替代方法?提前致谢。
最佳答案
Ethan,有时候你只需要放慢速度来帮助 C 就位。在您的情况下,您的数据显然会在每行的起始行中包含分类字符。后面可能跟着一两个数字,您需要相应地阅读和处理。您的问题由您的数据集定义。
值得庆幸的是,您可以利用面向行的输入函数fgets
或getline
,然后一次调用sscanf
为每个喜欢处理所有情况。读取该行后,将其传递给类似于以下内容的 sscanf
调用:
rtn = sscanf (buf, "%c %d %d", &c, &v1, &v2); /* always check return */
保留返回值(即根据您的格式字符串发生的成功转换次数),您可以开始回答有关您期望的数据的逻辑问题。然而,在盲目比较是否有三个、两个或更少的转换之前,您可以通过查看缓冲区中的第一个字符来回答简单的问题。如果您需要小写字母来开始有效行,那么您所需要做的就是取消引用缓冲区以获取第一个字符,然后检查它是否在 'a' - 'z'
之间。如果不是,则该行无效。类似地,如果您检查第一个字符并发现它是 0
(终止字符)或 '\n'
,那么您就知道该行是空的,您无需费心不再这样了。这两个测试将过滤掉所有杂乱的内容,至少留下可能符合您的标准的行。例如简单地检查:
if (rtn == 0) { /* no successful conversions took place */
fprintf (stderr, "error: no values parsed from line.\n");
continue;
}
if (!*buf || *buf == '\n') { /* check if buf was empty line */
fprintf (stderr, "error: line is empty or contians only newline.\n");
continue;
}
if (*buf < 'a' || 'z' < *buf) { /* check first char not a-z */
fprintf (stderr, "error: no lowercase char beginning line.\n");
continue;
}
让您确信至少您所操作的线路有合理的机会与您正在寻找的内容相匹配。
现在您可以执行 if ... else if .... else if ....
(这完全没问题),或者因为您知道您主要关心的是检查值1-3
,switch
语句对于处理剩余的行有意义。例如,您可以执行类似以下操作来解析那些值得查看的行中的值:
switch (rtn) { /* switch on number of successful conversions */
case 3: /* three successful conversions */
printf ("all values: '%c' %d %d\n", c, v1, v2);
break;
case 2: /* two successful conversions */
printf ("two values: '%c' %d\n", c, v1);
break;
default: /* one or less (need at least two */
fprintf (stderr, "error: no character and value on line.\n");
}
将所有这些部分放在一起,您可以执行类似的操作:
#include <stdio.h>
#define MAXC 256
int main (void) {
char buf[MAXC] = "";
while (fgets (buf, MAXC, stdin)) /* read each line into buf */
{
char c;
int v1, v2, rtn; /* vars for values and sscanf return */
rtn = sscanf (buf, "%c %d %d", &c, &v1, &v2);
if (rtn == 0) { /* no successful conversions took place */
fprintf (stderr, "error: no values parsed from line.\n");
continue;
}
if (!*buf || *buf == '\n') { /* check if buf was empty line */
fprintf (stderr, "error: line is empty or contians only newline.\n");
continue;
}
if (*buf < 'a' || 'z' < *buf) { /* check first char not a-z */
fprintf (stderr, "error: no lowercase char beginning line.\n");
continue;
}
switch (rtn) { /* switch on number of successful conversions */
case 3: /* three successful conversions */
printf ("all values: '%c' %d %d\n", c, v1, v2);
break;
case 2: /* two successful conversions */
printf ("two values: '%c' %d\n", c, v1);
break;
default: /* one or less (need at least two */
fprintf (stderr, "error: no character and value on line.\n");
}
}
return 0;
}
示例输入文件
$ cat dat/input.txt
a -1109180 699692587
a 1213834231 -226769626
c 994957275 2082945813
e 1213834231
还有一个更困惑的文件:
$ cat dat/rows.txt
a -1109180 699692587
a quick brown fox jumps over the lazy dog
a 1213834231 -226769626
c 994957275 2082945813
227 isn't good
e 1213834231
应该提供一个良好的测试来查看代码是否满足您的需要。通过代码运行数据可以提供:
示例使用/输出
$ /bin/sscanf_mixed <dat/input.txt
all values: 'a' -1109180 699692587
all values: 'a' 1213834231 -226769626
all values: 'c' 994957275 2082945813
two values: 'e' 1213834231
梅西耶文件输出:
$ ./bin/sscanf_mixed <dat/rows.txt
all values: 'a' -1109180 699692587
error: no character and value on line.
all values: 'a' 1213834231 -226769626
error: line is empty or contians only newline.
all values: 'c' 994957275 2082945813
error: no lowercase char beginning line.
two values: 'e' 1213834231
正如您所看到的,两个输入文件提供了相同数量的转换,第二个输入文件只是记录遇到不合格行时发生的错误或问题。
仔细检查一下,如果有任何问题请告诉我。有很多方法可以解决问题的逻辑,但无论您选择哪种方式,您都希望确保构建的所有输入例程足够灵活,能够处理您应该合理期望的条件(空行等...)在现实世界使用中遇到的情况。
关于c - 使用 C 中的 sscanf 解析标准输入流中的数字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43084250/
我最近在读 CSAPP。在 10.9 节中,它说标准 I/O 不应该与 socket 一起使用,原因如下: (1) The restrictions of standard I/O Restricti
似乎是一个足够标准的问题,可以保证解决方案中的标准设计: 假设我想在文件中写入 x+2(或更少)个字符串。 x 字符串构成一个部分的内容,这两个字符串构成该部分的页眉和页脚。要注意的是,如果内容中没有
代码版本管理 在项目中,代码的版本管理非常重要。每个需求版本的代码开发在版本控制里都应该经过以下几个步骤。 在master分支中拉取该需求版本的两个分支,一个feature分支,
我有以下sql查询,我需要获取相应的hibernate条件查询 SELECT COUNT(DISTINCT employee_id) FROM erp_hr_payment WHERE payment
所以我正在编写一些代码,并且最近遇到了实现一些 mixin 的需要。我的问题是,设计混音的正确方法是什么?我将使用下面的示例代码来说明我的确切查询。 class Projectile(Movable,
我的环境变量包含如下双引号: $echo $CONNECT_SASL_JAAS_CONFIG org.apache.kafka.common.security.plain.PlainLoginModu
示例: /** * This function will determine whether or not one string starts with another string. * @pa
有没有办法在 Grails 中做一个不区分大小写的 in 子句? 我有这个: "in"("name", filters.tags) 我希望它忽略大小写。我想我可以做一个 sqlRestriction
我搜索了很长时间,以查找将哪些boost库添加到std库中,但是我只找到了一个新库的完整列表(如此处:http://open-std.org/jtc1/sc22/wg21/docs/library_t
我已经通过使用这个肮脏的黑客解决了我的问题: ' Filter managerial functions ActiveSheet.Range("$A$1:$BW$2211").Auto
因此,我很难理解我需要遵循的标准,以便我的 Java 程序能够嵌入 HTML。我是否只需将我的主类扩展到 Applet 类,或者我还需要做更多的事情吗?另外,在我见过的每个 Applet 示例中,它都
我对在 Hibernate 中使用限制有疑问。 我必须创建条件,设置一些限制,然后选择日期字段最大值的记录: Criteria query = session.createCriteria(Stora
我有标准: ICriteria criteria = Session.CreateCriteria() .SetFetchMode("Entity1", FetchMo
我很难编写条件来选择所有子集合或孙集合为空的实体。我可以将这些作为单独的条件来执行,但我无法将其组合成一个条件。 类结构: public class Component { p
@Entity class A { @ManyToMany private List list; ... } @Entity class B { ... } 我想使用条件(不是 sql 查询)从 A
我的数据库中有以下表结构: Table A: Table B: Table C: _______________
请帮助我: 我有下一张 table : 单位 ID 姓名 用户 ID 姓名 利率 单位 ID 用户 ID 我不明白如何从 SQL 创建正确的条件结构: 代码: SELECT * FROM Unit W
我正在构建一个包含项目的网站,每个项目都有一个页面,例如: website.com/book/123 website.com/film/456 website.com/game/789 每个项目都可以
我需要使用两个属性的组合来过滤结果列表。一个简单的 SQL 语句如下所示: SELECT TOP 10 * FROM Person WHERE FirstName + ' ' + LastName L
我有一个“ super 实体”SuperEntity 和三个扩展父类(super class)的实体 ChildEntity1、...、ChildEntity3。 搜索数据库中的所有实体很容易,即我们
我是一名优秀的程序员,十分优秀!