- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
给定一个 4 行的文本文件:以逗号 (,) 作为分隔符分隔。我通过使用 fgets 获取每一行并将 ISBN (978-xxxxxxxxxx) 与用户提供的 ISBN 进行比较来定位特定的 ISBN。这很好用。
即使 fgets() 到文件的最后一行。它仍然返回正确的信息。但是,当我试图将字符串的每个元素过滤到其受尊重的结构成员中以通过套接字发送时。最后一个元素返回所有正确的内容,直到最后 4 个元素/字段。除了文件的最后一行,此错误不会发生。
我认为这是一个 EOF 错误,但是我不太精通 sscanf() 以理解为什么会这样。
如果我要打印出 linebuf,它会返回正确的(未解析的)行。但是如果我打印出我所有的数据。它返回第三行数据的一部分。具体来说,版本、份数、可用份数
9780132126953,Andrew Tanenbaum & David Wetherall,Computer Networks,5,2011,Prentice-Hall,5,2
9780123745408,Michael Donahoo & Kenneth Calvert,TCP/IP Sockets in C,2,2009,Morgan Kaufman,3,0
9780133354690,William Stallings,Cryptography and Network Security,6,2014,Prentice-Hall,3,3
9780072467505,Yale Patt & Sanjay Patel,Introduction to Computing Systems from bits & gates to C & beyond 2,2004,McGraw-Hill,1,0
我的代码:
while (fgets(linebuf, 1024, file) != NULL) {
sscanf(linebuf, "%[^,], %[^,], %[^,], %u, %u, %[^,], %u, %u\n",
bufferISBN, bufferAuthor, bufferTitle,
&bufferEdition, &bufferYear, bufferPublisher,
&bufferInventory, &bufferAvailable
);
if (strcmp(temp->isbn, bufferISBN) == 0) { // found correct line, add data to struct
mssg.respType = Okay; // enum
mssg.requestID = temp->requestID;
strcpy(mssg.isbn, bufferISBN); // needs fixing
strcpy(mssg.authors, bufferAuthor);
strcpy(mssg.title, bufferTitle);
strcpy(mssg.publisher, bufferPublisher);
mssg.edition = bufferEdition;
mssg.year = bufferYear;
mssg.inventory = bufferInventory;
mssg.available = bufferAvailable;
}
注意 sscanf() 的格式,我也不确定它是否正确:
"%[^,], %[^,], %[^,], %u, %u, %[^,], %u, %u\n"
我也知道我正在使用大量的缓冲区变量。
编辑:当我限制标题的长度时。它返回正常。这是为什么?
最佳答案
有时换行符会离开文本文件的最后一行。要检查,请执行 od -t x1 <filename>
最后一个字符应该是 0a
如果不是,您可以使用文本编辑器清理文件并添加换行符。
或者,您可以稍微更改代码来处理此问题:
while (fgets(linebuf, 1024, file) != NULL) {
char *cp = strchr(linebuf, '\n');
if (cp != NULL)
*cp = 0;
sscanf(linebuf, "%[^,], %[^,], %[^,], %u, %u, %[^,], %u, %u",
关于c - sscanf() 返回部分前几行数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33404620/
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我在程序中遇到了以下行。通过阅读手册,我知道 sscanf 从 argv[2] 指向的任何地方复制,但我不确定为什么格式被指定为 %d,同时指定为 %c (我见过其他双引号中包含更多格式说明符的示例)
我可以使用字符指针 (char *) 作为 sscanf() 函数中的输出字符串吗?考虑到我不知道字符串的长度(这就是我使用指针的原因)。 char *name; sscanf(data, "Name
我有一个表单的输入字符串 char *s = "one.two three" 我想把它分成 3 个字符串变量。我在做 sscanf(s, "%s.%s %s", one, two, three); 但
我一直在尝试让 sscanf 使用字符类识别一种相当简单的格式。我注意到,当我为 sscanf 提供 char* 以匹配字符类时,它也会覆盖前一个字节,就好像它需要一个指向 2 个字节的指针一样。 我
我正在将 MAC 地址的字符串表示形式转换为 UINT8 的数组s 定义为 unsigned char 。我很好奇为什么sscanf()当我读入 UINT8 数组时,将读取全 0当我读入常规 32 位
我有一个包含空格和标签的字符串,例如: sp|P02671|FIBA_HUMAN Fibrinogen alpha chain OS=Homo sapiens GN=FGA PE=1 SV=2 我只想
我正在尝试在 C 中使用 sscanf 函数,但它不读取格式是必需的,我已经阅读了该函数的文档并遵循了示例,但它对我来说仍然效果不佳,因此我想要一些建议.. int main() { long i
我需要在c中解析一个格式为“foo=%d”的字符串,我需要检查格式是否正确并读取int值。 我的初始代码是: int foo_set = 0; int foo; if (sscanf(text, "f
在下面的代码中,我想读取十六进制字符串 'a' 中的前 2 个字符,使用 sscanf 将它们转换为相应的字节值并将结果放入 'b'。不应对“a”执行任何修改。 #include #include
我试图找出我应该给 sscanf 的模式。 我有一个字符串 abcde(1GB)。我想提取 1 和 GB。我在用 char list[]= "abcde(1GB)"; int memo
我应该得到一个可以是以下任何格式的输入行: 单词 1 和单词 2 之间必须有空格。 单词 2 和单词 3 之间必须有逗号。 单词 2 和单词 3 之间不一定要有空格,但可以有任意数量的空格。 如何分离
最近发现的对 GTA 冗长加载时间 (1) 的解释表明 sscanf() 的许多实现调用 strlen()在他们的输入字符串上为与其他扫描函数( scanf() , fscanf() ...)共享的内
我需要将字符串分成两部分,字符串的第一列是第一部分,字符串的其余部分是第二部分。第一部分需要存储在 first_str 中,第二部分需要存储在 rest_str 中。 我正在使用 sscanf 来实现
我需要从char数组中提取数字,它以hh:mm的格式存储值(示例20:20) 我尝试使用sscanf函数将hh提取为小时变量,将mm提取为分钟变量。 直到时间类似于0number:0number或如果
所以我想知道 sscanf 在遇到像这样的行时是如何工作的: sscanf(input_string, "%s %s %s", cmd1, cmd2, cmd3); 但是假设 input_string
我在以下代码中遇到 sscanf() 问题: void num_check(const char*ps){ char *ps1=NULL; int number=0; unsigned sum_num
谁能解释一下为什么在下面的代码中没有拆分字符串 #include int main(void) { char name[] = "first:last"; char first[20
我正在尝试解析一个 URL,并编写了这段代码: #include int main() { char host[100]; char port[100]; char path
我正在为我正在制作的程序使用 AT 命令,但在使用 sscanf() 函数解析它们时遇到问题。 例如,如果我执行此命令: "AT\r\r\nOK\r\n" 我想:* 在第一次调用时,仅获取“AT”部分
我是一名优秀的程序员,十分优秀!