- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
这个小程序的目的是比较两个单独文件(file1.csv 和 file2.csv)中的字符串,并将其结果提供给 file3.csv。如果在 file1.csv 中找到 file2.csv 中的字符串,则程序将 file1.csv 中的字符串复制到 file3.csv。
file1.csv 的内容(6 列):
10000001 text1 text1 text1 text1 text1
10000002 text2 text2 text2 text2 text2
10000003 text3 text3 text3 text3 text3
10000004 text4 text4 text4 text4 text4
10000005 text5 text5 text5 text5 text5
10000006 text6 text6 text6 text6 text6
10000007 text7 text7 text7 text7 text7
10000008 text8 text8 text8 text8 text8
10000009 text9 text9 text9 text9 text9
10000010 text10 text10 text10 text10 text10
10000011 text11 text11 text11 text11 text11
10000012 text12 text12 text12 text12 text12
10000013 text13 text13 text13 text13 text13
10000014 text14 text14 text14 text14 text14
10000015 text15 text15 text15 text15 text15
10000016 text16 text16 text16 text16 text16
10000017 text17 text17 text17 text17 text17
10000018 text18 text18 text18 text18 text18
10000019 text19 text19 text19 text19 text19
10000020 text20 text20 text20 text20 text20
10000021 text21 text21 text21 text21 text21
10000022 text22 text22 text22 text22 text22
10000023 text23 text23 text23 text23 text23
10000024 text24 text24 text24 text24 text24
10000025 text25 text25 text25 text25 text25
file2.csv的内容(只有一栏):
10000001
10000003
10000004
10000006
10000007
10000008
10000009
10000011
10000012
10000015
10000025
预期结果将是:
10000001 text1 text1 text1 text1 text1
10000003 text3 text3 text3 text3 text3
10000004 text4 text4 text4 text4 text4
10000006 text6 text6 text6 text6 text6
10000007 text7 text7 text7 text7 text7
10000008 text8 text8 text8 text8 text8
10000009 text9 text9 text9 text9 text9
10000011 text11 text11 text11 text11 text11
10000012 text12 text12 text12 text12 text12
10000015 text15 text15 text15 text15 text15
10000025 text25 text25 text25 text25 text25
我使用了strstr()函数来比较字符串,但是没有用,代码如下:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char line[150][80] = {0};
char line2[150][80] = {0};
int i = 0, b = 0;
FILE *file1 = fopen("file1.csv", "r");
FILE *file2 = fopen("file2.csv", "r");
FILE *file3 = fopen("file3.csv", "w");
while (fscanf(file1, "%79[^\n]\n", line[i]) != EOF) {
i++;
while (fscanf(file2, "%79[^\n]\n", line2[b]) != EOF) {
b++;
}
if (strstr(line[i],line2[b]))
fprintf(file3, "%s\n", line[i]);
}
fclose(file1);
fclose(file2);
fclose(file3);
return 0;
}
提前致谢!
最佳答案
正如 unwind 和其他评论者正确指出的那样,在每次 file1.csv
阅读迭代时重新阅读 file2.csv
是没有意义的。只需读取一次并循环遍历 line2[]
数组即可。
其次,您可能会逐行处理 file1.csv
并在处理完后立即忘记当前行的内容,因此制作 line[][]
数组也不是必需的。
这是你修改后的代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define CHECK_FILE_OPEN(file, name) \
if (file == NULL) { \
printf("Failed to open %s\n", name); \
return 1; \
}
int main()
{
char line[150] = "";
char line2[150][80] = {0};
int b = 0;
int filterCount = 0;
FILE *file1 = fopen("file1.csv", "r");
CHECK_FILE_OPEN(file1, "file1.csv");
FILE *file2 = fopen("file2.csv", "r");
CHECK_FILE_OPEN(file2, "file2.csv");
FILE *file3 = fopen("file3.csv", "w");
CHECK_FILE_OPEN(file3, "file3.csv");
while (fscanf(file2, "%79[^\n]\n", line2[b]) != EOF) {
b++;
}
filterCount = b;
while (fscanf(file1, "%79[^\n]\n", line) != EOF) {
for (b = 0; b < filterCount; b++) {
if (strstr(line,line2[b])) {
fprintf(file3, "%s\n", line);
break;
}
}
}
fclose(file1);
fclose(file2);
fclose(file3);
return 0;
}
但是,您的输入数据似乎足够具体,可以做出一些优化假设。特别是,(a) 所有文件都按第一列值排序,并且 (b) 第二列只是第一列的缩减副本(根据行索引值)。
在这种情况下,您可能希望实现一次处理。逐行扫描两个文件,比较索引值。然后在每次迭代时前进到第一个文件的下一行。从第二个文件开始,只有在第一个文件中找到当前行时才移动到下一行。
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define CHECK_FILE_OPEN(file, name) \
if (file == NULL) { \
printf("Failed to open %s\n", name); \
return 1; \
}
int main()
{
char line1[150] = "";
char line2[150] = "";
FILE *file1 = fopen("file1.csv", "r");
CHECK_FILE_OPEN(file1, "file1.csv");
FILE *file2 = fopen("file2.csv", "r");
CHECK_FILE_OPEN(file2, "file2.csv");
FILE *file3 = fopen("file3.csv", "w");
CHECK_FILE_OPEN(file3, "file3.csv");
bool eof1 = fscanf(file1, "%79[^\n]\n", line1) == EOF;
bool eof2 = fscanf(file2, "%79[^\n]\n", line2) == EOF;
while (!eof1 && !eof2) {
if (strstr(line1, line2)) {
fprintf(file3, "%s\n", line1);
eof2 = fscanf(file2, "%79[^\n]\n", line2) == EOF;
}
eof1 = fscanf(file1, "%79[^\n]\n", line1) == EOF;
}
fclose(file1);
fclose(file2);
fclose(file3);
return 0;
}
关于c - C语言中如何使用strstr()函数比较字符数组中的内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30568730/
我想使用 NetworkX Graph 对象作为 Python dict 中的键。但是,我不希望默认的比较行为(即通过对象的地址)。相反,我希望同构图是 dict 中相同元素的键。 此行为是否已在某处
这个问题已经有答案了: What is the most effective way for float and double comparison? (33 个回答) 已关闭 7 年前。 在您认为我
我正在学习 C 编程,为了练习,我找到了一个需要解决的任务。这有点像一个游戏,有人选择一个单词,其他人猜测字母。我必须检查有多少给定的单词可能是所选单词的正确答案。 输入: 3 3//数字 n 和 m
我两天前开始学习C,在做作业时遇到了问题。我们的目的是从字符数组中获取字符列表,并通过计算连续字符并将其替换为数字来缩短它。对“a4b5c5”说“aaaabbbbbccccc”。这是我到目前为止的代码
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
为什么我在 if 中的比较不起作用?答案应该是 8 但它返回 0。 function findMissing(missingArray){ var getArray = missing
我想知道为什么以下 JavaScript 比较会给出不同的结果。 (1==true==1) true (2==true==2) false (0==false==0) false (0==false)
我想知道是否有人可以帮助我完成这个程序。编写一个接受两个字符串的函数。该函数应该将这两个字符串与字典顺序上排在第一位的字符串组合起来。两个字符串之间应该有一个空格。在一行上打印结果字符串。在一行上打印
有谁知道一个免费的开源库(实用程序类),它允许您比较一个 Java bean 的两个实例并返回一个属性列表/数组,这两个实例的值不同?请发布一个小样本。 干杯 托马斯 最佳答案 BeanCompara
我是java新手。任何人都可以给出以下类声明的含义 public class ListNode, V> { K key; V value; ListNode next;
我需要用 C 语言计算和比较 3 种不同大小(100 * 100、1000 * 1000 和 10000 * 10000)的 2 个矩阵相乘的执行时间。我编写了以下简单代码来为 1000 * 1000
当我在 ACCESS 2007 中运行以下 SQL 时 Select Location, COUNT(ApartmentBuildings) AS TotalIBuildingsManaged Fro
根据我对互斥锁的了解——它们通常提供对共享资源的锁定功能。因此,如果一个新线程想要访问这个锁定的共享资源——它要么退出,要么必须不断轮询锁(并在等待锁时浪费处理器周期)。 但是,监视器具有条件变量,它
通常在编程中,不应该比较浮点数据类型是否相等,因为存储的值通常是近似值。 由于两个非整数 Oracle NUMBER 值的存储方式不同(以 10 为基数),是否可以可靠地比较它们是否相等? 最佳答案
使用 PowerShell 时,我们偶尔会比较不同类型的对象。一个常见的场景是 $int -eq $bool (即其中 0 -eq $false 、 0 -ne $true 和任何非零值仅等于真,但不
#include #define MAX 1000 void any(char s1[], char s2[], char s3[]); int main() { char string1[
我想比较两个日期。 从这两个日期中,我只使用 ToShortDateString() 获取日期组件, 如下所示。现在的问题是当我比较两个日期时。它的 throw 错误—— "Operator >= c
用户输入一个数字( float 或整数),并且它必须大于下限。 这是从 UITextField 获取数字的代码: NSNumberFormatter * f = [[NSNumberFormatter
我已经摆弄这段代码大约一个小时了,它让我难以置信。我认为解决方案相当简单,但我似乎无法弄清楚。无论如何,这里去。我制作了一个 javascript 函数来检查用户输入的字符,以便它只能接受 7 个字符
我不太明白为什么当我们在不覆盖 equals 的情况下比较具有相同类属性的两个实例时方法,它将给出 false .但它会给出 true当我们比较一个案例类的两个实例时。例如 class A(val
我是一名优秀的程序员,十分优秀!