![]() |
|
|
google unix.com
|
|||||||
| Forums | Register | Forum Rules | Links | Albums | FAQ | Members List | Calendar | Search | Today's Posts | Mark Forums Read |
| High Level Programming Post questions about C, C++, Java, SQL, and other programming languages here. |
More UNIX and Linux Forum Topics You Might Find Helpful
|
||||
| Thread | Thread Starter | Forum | Replies | Last Post |
| Extracting data from text file based on configuration set in config file | suparnbector | Shell Programming and Scripting | 3 | 08-10-2007 03:25 AM |
| Extracting Data from a File | oop | UNIX for Dummies Questions & Answers | 0 | 07-31-2007 12:48 PM |
| Extracting Data from xml file | nishana | Shell Programming and Scripting | 3 | 07-13-2007 08:17 AM |
| Extracting data from an AFP file | Dolph | UNIX for Advanced & Expert Users | 4 | 05-22-2007 05:29 AM |
| extracting recursive data file | bbeugie | UNIX for Dummies Questions & Answers | 1 | 06-16-2004 06:48 AM |
![]() |
|
|
LinkBack | Thread Tools | Search this Thread | Rate Thread | Display Modes |
|
|
|
||||
|
Help in extracting data with command from file in C
Hi,
I have a file which stores the following array :- 1,2,3,4,5.........16,17,18,19,20 This file has few hundreds of inputs of these lines. I would like to read this file one line at a time; and assign to an array which is separated by ",". I tried to do fgets command however, segmentation fault occurs.I suspect its because I get the one whole line without concatenate the , . Please help. Thanks. |
|
||||
|
Hi,
The main motivation is that I would like to do a upper shell command on top of the binaries with different number of input files. e.g ./binary.exe a.txt ./binary.exe b.txt ....where these a.txt and b.txt are input files. The problem now i am facing is particular only on one input file before even I could move to perform some shell stuffs. Below are some code snippet which I face error of seg fault i described earlier on. #include <stdio.h> #include <stdlib.h> #include <string.h> #define SIZE 20 main (int argc, char *argv[]) { FILE *cfPtr; /* for reading data to expand.txt for vector based */ FILE *tfPtr; /* for reading data from svmkb.txt */ int t[SIZE]; int subs[7]; int label=0; int i; char filename[5000]; char dump; strcpy(filename,argv[2]); tfPtr = fopen(filename,"r"); if (tfPtr == NULL) { printf("Can't find input file %s",filename); exit(-1); } /*initialization for statement 1,2 and 4*/ for (i=1; i< 5;i++){ subs[i]=0; } while(!feof(tfPtr)) { for (i=0; i<16; i++) { fscanf(filename, "%d", t[i]); fscanf(filename, "%c", dump); } while(t[SIZE-16]>0){ subs[1]=1; subs[4]=1; label=0; t[SIZE-16]--; } } fclose(tfPtr); exit(0); return 0; } ./test.c a.txt gives me Segmentation Fault(Core Dump) For your information, my a.txt looks like:- 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0 ,1,0,1,0 ......... ........ .... |
|
||||
|
A couple things. Code:
while(!feof(tfPtr))
{
for (i=0; i<16; i++)
{
fscanf(filename, "%d", t[i]);
fscanf(filename, "%c", dump);
}
Word to the wise: If fscanf() doesn't read the data specified it won't advance the file pointer. You are going to see some very undesirable behavior if you specify an incorrectly formatted file. You also should do bounds checking and add debugging code when reading from a datasource and the user. It's much easier than hoping it works. Secondly fscanf()'s first argument is pointer to type FILE but you are passing an array of type char (filled from argv[2]). Thirdly you are not passing the address of a pointer to type int as third argument to fscanf. That's probably your segfault. HTH ... |
|
||||
|
Quote:
Code:
strcpy(filename, argv[1]); |
![]() |
| Bookmarks |
| Thread Tools | Search this Thread |
| Display Modes | Rate This Thread |
|
|