- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在尝试读取 .txt 文件时遇到问题,文件示例:“12345 qwe>rty 12345 q=wert qe/ry”尝试读取超过 50 000 条相似的行,将它们与另一个(也从文档中读取)数组进行比较,但程序每次都会制动...代码支持比较 2 个数组,如果它们匹配,则在新文档中打印它们。希望我解释得很好......`
#include <stdio.h>
#define max 57000
main()
{
int i, j, n;
char (*ime[200])[max], (*grad[200])[max], (*adresa[200])[max];
int rb[max], rbk[max], posta[max], check[max];
FILE *svi = fopen("C:\\Users\\Fujitsu\\Desktop\\001.txt", "r");
FILE *kupci = fopen("C:\\Users\\Fujitsu\\Desktop\\002txt", "r");
FILE *izlaz = fopen("C:\\Users\\Fujitsu\\Desktop\\003.txt", "w");
// reading from 001.txt//
//
printf("1"); //some kind of check point
for (i = 2; i < 56300; i++)
{
fscanf(svi, "%d%s%d%s%s", &rb[i], &ime[i], &posta[i], &grad[i], &adresa[i]);
check[i] = 0;
fscanf(kupci, "%d", &n);
rbk[n] = 0;
}
//matching 001 i 002//
printf("2");
for (i = 2; i < 56300; i++)
{
if (check[i] == rbk[i])
{
check[i] = 1;
}
//stampanje u novu datoteku 003 //
if (check[i] == 0)
{
fprintf(izlaz, "%szt%d\t%s\t%s\t\n", ime[i], posta[i], grad[i],
adresa[i]);
;
}
}
fclose(svi);
fclose(kupci);
fclose(izlaz);
printf("done");
getch();
}
提前谢谢
最佳答案
这里有几个问题。造成问题的直接原因可能是您没有检查是否成功打开文件,并且其中一个名称缺少 .
:
FILE *svi = fopen("C:\\Users\\Fujitsu\\Desktop\\001.txt", "r");
FILE *kupci = fopen("C:\\Users\\Fujitsu\\Desktop\\002txt", "r"); // <<-- .txt???
FILE *izlaz = fopen("C:\\Users\\Fujitsu\\Desktop\\003.txt", "w");
尚不清楚 rbk
数组是否已正确初始化。
很明显,您不希望指向数组的指针:
char (*ime[200])[max], (*grad[200])[max], (*adresa[200])[max];
坦率地说,这些令人兴奋;他们对于当前的目的也是完全错误的。宏通常也全部大写(因此 MAX
而不是 max
)。您可能正在寻找:
char ime[MAX][200], grad[MAX][200], adresa[MAX][200];
这是三个 MAX
条目数组,每个条目长度为 200 个字符。这至少是“明智的”,因为它为您提供了分配的空间来读取;这是不明智的,因为它可能会浪费大量空间,但至少它不会崩溃。
您的代码应检查 fscanf()
调用是否成功。第一个 fscanf()
调用的参数需要修复,以识别 ime[i]
等是数组,不需要前面的 &
其中。检查点打印语句需要以换行符结束;否则,它们就不会及时出现。我也不喜欢输出行末尾的尾随空白和制表符。
总而言之,这些变化产生:
#include <stdio.h>
#include <string.h>
#define MAX 57000
int main(void)
{
int i, n;
char ime[MAX][200], grad[MAX][200], adresa[MAX][200];
int rb[MAX], rbk[MAX], posta[MAX], check[MAX];
FILE *svi = fopen("C:\\Users\\Fujitsu\\Desktop\\001.txt", "r");
FILE *kupci = fopen("C:\\Users\\Fujitsu\\Desktop\\002.txt", "r");
FILE *izlaz = fopen("C:\\Users\\Fujitsu\\Desktop\\003.txt", "w");
if (svi == 0 || kupci == 0 || izlaz == 0)
{
fprintf(stderr, "Failed to open at least one file\n");
return 1;
}
memset(rbk, '\xFF', sizeof(rbk)); // Not zero - that's too friendly.
printf("1\n"); //some kind of check point
for (i = 2; i < MAX; i++)
{
if (fscanf(svi, "%d%s%d%s%s", &rb[i], ime[i], &posta[i], grad[i], adresa[i]) != 5)
break;
check[i] = 0;
if (fscanf(kupci, "%d", &n) != 1)
break;
rbk[n] = 0;
}
int max = i;
printf("2\n");
for (i = 2; i < max; i++)
{
if (check[i] == rbk[i])
check[i] = 1;
if (check[i] == 0)
fprintf(izlaz, "%s\t%d\t%s\t%s\n", ime[i], posta[i], grad[i], adresa[i]);
}
fclose(svi);
fclose(kupci);
fclose(izlaz);
printf("done\n");
return 0;
}
它编译时没有警告。我无法弄清楚这些文件是如何组织的;似乎 002.txt
并不简单地按顺序包含数字 1..N,但尚不清楚它们应该如何排序。因此,该代码未经测试,尤其是因为我的 Unix 机器上没有 C:
驱动器。然而,这是一个不同的问题。 (这也是懒惰:我完全可以在当前目录中创建一个文件 C:\Users\Fujitsu\001.txt
...)
关于c - 从文件读取时使用字符串数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16751732/
如何使用 SPListCollection.Add(String, String, String, String, Int32, String, SPListTemplate.QuickLaunchO
我刚刚开始使用 C++ 并且对 C# 有一些经验,所以我有一些一般的编程经验。然而,似乎我马上就被击落了。我试过在谷歌上寻找,以免浪费任何人的时间,但没有结果。 int main(int argc,
这个问题已经有答案了: In Java 8 how do I transform a Map to another Map using a lambda? (8 个回答) Convert a Map>
我正在使用 node + typescript 和集成的 swagger 进行 API 调用。我 Swagger 提出以下要求 http://localhost:3033/employees/sear
我是 C++ 容器模板的新手。我收集了一些记录。每条记录都有一个唯一的名称,以及一个字段/值对列表。将按名称访问记录。字段/值对的顺序很重要。因此我设计如下: typedef string
我需要这两种方法,但j2me没有,我找到了一个replaceall();但这是 replaceall(string,string,string); 第二个方法是SringBuffer但在j2me中它没
If string is an alias of String in the .net framework为什么会发生这种情况,我应该如何解释它: type JustAString = string
我有两个列表(或字符串):一个大,另一个小。 我想检查较大的(A)是否包含小的(B)。 我的期望如下: 案例 1. B 是 A 的子集 A = [1,2,3] B = [1,2] contains(A
我有一个似乎无法解决的小问题。 这里...我有一个像这样创建的输入... var input = $(''); 如果我这样做......一切都很好 $(this).append(input); 如果我
我有以下代码片段 string[] lines = objects.Split(new string[] { "\r\n", "\n" }, StringSplitOptions.No
这可能真的很简单,但我已经坚持了一段时间了。 我正在尝试输出一个字符串,然后输出一个带有两位小数的 double ,后跟另一个字符串,这是我的代码。 System.out.printf("成本:%.2
以下是 Cloud Firestore 列表查询中的示例之一 citiesRef.where("state", ">=", "CA").where("state", "= 字符串,我们在Stack O
我正在尝试检查一个字符串是否包含在另一个字符串中。后面的代码非常简单。我怎样才能在 jquery 中做到这一点? function deleteRow(locName, locID) { if
这个问题在这里已经有了答案: How to implement big int in C++ (14 个答案) 关闭 9 年前。 我有 2 个字符串,都只包含数字。这些数字大于 uint64_t 的
我有一个带有自定义转换器的 Dozer 映射: com.xyz.Customer com.xyz.CustomerDAO customerName
这个问题在这里已经有了答案: How do I compare strings in Java? (23 个回答) 关闭 6 年前。 我想了解字符串池的工作原理以及一个字符串等于另一个字符串的规则是
我已阅读 this问题和其他一些问题。但它们与我的问题有些无关 对于 UILabel 如果你不指定 ? 或 ! 你会得到这样的错误: @IBOutlet property has non-option
这两种方法中哪一种在理论上更快,为什么? (指向字符串的指针必须是常量。) destination[count] 和 *destination++ 之间的确切区别是什么? destination[co
This question already has answers here: Closed 11 years ago. Possible Duplicates: Is String.Format a
我有一个Stream一个文件的,现在我想将相同的单词组合成 Map这很重要,这个词在 Stream 中出现的频率. 我知道我必须使用 collect(Collectors.groupingBy(..)
我是一名优秀的程序员,十分优秀!