
結果テキストファイルから特定の値のみ抽出するプログラムを作成しているのですが、思うように動いてくれません。どなたか教えてくださいませんか。お願いします。
<テキストファイルの形式>
様々な文字や記号slm,0.070000,-53458.000000様々な文字や記号
これが1行に4つ程含まれるものが10行ほどあるのですが、
2つ目のカンマの後の数値部分のみ抽出したいのです。
<プログラム>
char line[MAXLINE];
char a1[]="slm";
char *r;
char *s[2];
while (fgets(line, MAXLINE, fp) != NULL){
if(strstr(line, a1)!=NULL){
for (r = line ;r = strstr(r, a1); r += 27 ){
for(int p=0;p>2;p++){
s[p]=strtok( strstr(r, a1), "," );
printf("%s",s[3]);
}
}
printf(" \n");
i++;
}
}
そこでこのようなプログラムを作ってみたのですが、実行すると何も表示されません。
どなたか改善策を教えてください。本当に困っています。
A 回答 (7件)
- 最新から表示
- 回答順に表示
No.7
- 回答日時:
> こちらのdouble型のaとbは何のための配列なのでしょうか?
配列と書いたのは
> これが1行に4つ程含まれるものが10行ほどあるのですが、
とあったので、それら全部を記憶しておく必要があるなら、配列とか用意するように修正してください。という意味で、a, b 自体配列でもなんでもありません。あくまでサンプルコードとして提示してみただけで、こちらとしては数値に変換していいのかどうかも知りません。
ですから文字列として処理する必要があるなら、全然見当外れとなります。
No.6
- 回答日時:
> char *s[3];
> strcpy(s[p],strtok( NULL, ",") );
これは値不定のポインタ配列 s[3] に、いきなり strtok() の返り値のアドレスからコピーしようということです。本当に内容をコピーして保存したいなら s[] のそれぞれに実体を与えてからじゃなきゃダメです。
それに strtok() 使うなら
char *q;
for (q = r; q = strtok(q, ","); q = NULL) {
みたいに 2 回目以降の呼び出しを NULL にしなければなりません。
ただ最終的に数値として取り込みたいなら
double a, b;
for (r = line ;r = strstr(r, a1); r += i) {
if (sscanf(r, "slm ,%lf ,%lf%n", &a, &b, &i) < 2)
i = sizeof(a1)-1;
あとは配列に追加してくなり、その場で加工するなり。
この回答への補足
回答ありがとうございます。
double a, b;
for (r = line ;r = strstr(r, a1); r += i) {
if (sscanf(r, "slm ,%lf ,%lf%n", &a, &b, &i) < 2)
i = sizeof(a1)-1;
こちらのdouble型のaとbは何のための配列なのでしょうか?
何度もすみませんがご教授願います。
No.4
- 回答日時:
それから、配列の基本もおわかりではないようですね。
>char *s[2];
という定義で、正しく参照できるのは、s[0]とs[1]の「2個」です。
定義時の*s[2]は、0番から始まる「2個の領域」という意味です。
したがって、
>printf("%s",s[2]);
s[2]は定義範囲外の領域です。また、ループの中で毎回出力しているのは意図が不明です。
この回答への補足
詳しい回答を何度もありがとうございます!
ご指摘くださった部分を改良して
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAXLINE 2094
int main(void){
FILE *fp;
int i=1;
char line[MAXLINE];
char a1[]="SIL";
char a2[]="acoustic=";
char *r;
char *s[3];
/* ファイルオープン */
if ((fp = fopen( "C:\\Users\\石原慎也\\Desktop\\N_best.result", "r" )) == NULL){
printf("ファイルオープンに失敗しました。B\n");
exit(1);
}
/* データ処理 */
while (fgets(line, MAXLINE, fp) != NULL){
if(strstr(line, a1)!=NULL){
for (r = line ;r = strstr(r, a1); r += 27 ){
for(int p=1;p<=2;p++){
strcpy(s[p],strtok( NULL, ",") );
printf("%s",s[2]);
}
}
printf(" \n");
i++;
}
}
}
という風にしてみたんですが、プログラムが動きません・・。
他にどこか悪いところありますか?
何度もごめんなさい。
No.3
- 回答日時:
>for(int p=1;p>2;p++){
いや、ですからね、質問者さんはfor文の継続条件を勘違いされていると思うんですよ。
p>2
というのは、「pが2より大きい間」という意味です。
「pが2より大きくなるまで」という意味「ではありません」。
No.2
- 回答日時:
strstr()の引数が、反対です。
ファイルポインタはどこで定義されていますか? 一部ではなく、プログラム全体を掲載してほしいです。この回答への補足
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAXLINE 2094
int main(void){
FILE *fp;
int i=1;
char line[MAXLINE];
char a1[]="slm";
char *r;
char *s[2];
/* ファイルオープン */
if ((fp = fopen( "ファイルへのダイレクトパス", "r" )) == NULL){
printf("ファイルオープンに失敗しました。B\n");
exit(1);
}
/* データ処理 */
while (fgets(line, MAXLINE, fp) != NULL){
if(strstr(line, a1)!=NULL){
for (r = line ;r = strstr(r, a1); r += 27 ){
strcpy(s[0],strtok( strstr(r, a1), ",") );
for(int p=1;p>2;p++){
strcpy(s[p],strtok( NULL, ",") );
printf("%s",s[2]);
}
}
printf(" \n");
i++;
}
}
}
回答ありがとうございます。こちらが全体のプログラムなんですが・・・。少々変えました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# c言語 プログラムのエラー 1 2023/02/11 20:31
- C言語・C++・C# Cのdoubleの浮動小数点表示について 3 2023/04/17 13:14
- C言語・C++・C# カードシャッフルのブログラムを使ってc言語でブラックジャックをしたい 2 2022/04/12 15:13
- C言語・C++・C# c言語の問題です 3 2023/01/10 16:15
- C言語・C++・C# このプログラミング誰か教えてくれませんか 1 2022/06/02 15:27
- C言語・C++・C# c言語配列の結合についてです。 なぜうまくいかないのでしょうか。 #include <stdio.h 4 2022/05/30 22:42
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
キーボード配列をもとに戻す方法
-
複数の選択範囲の行番号を個別...
-
配列を使わずに、変数名を動的...
-
9枚の写真がA4 1枚に印刷できま...
-
多次元配列を分かりやすく教え...
-
構造体配列を引数とするDLL作成...
-
C# Listを使わずに2次元配列の...
-
現在、C/C++ で作成したプログ...
-
C言語のオーバーフローについて
-
ExcelVBAで質問です。離れた二...
-
【速いブラインドタッチ】手を...
-
配列と他の変数のメモリ領域重...
-
2次元配列を戻り値とする関数?
-
4勤2休のシフト作成
-
C言語 配列の再初期化
-
テキストファイルから文字列を...
-
多次元配列のポインタ渡し
-
C言語 配列の長さの上限
-
VB.netでRadioButtonを配列にし...
-
reallocについて
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
C言語 配列の長さの上限
-
配列を使わずに、変数名を動的...
-
C# Listを使わずに2次元配列の...
-
【速いブラインドタッチ】手を...
-
配列をEraseしてもメモリが開放...
-
テキストファイルから文字列を...
-
先頭アドレスとは何ですか?
-
配列で格納したものをmsgboxで...
-
複数の選択範囲の行番号を個別...
-
C# 配列の変数宣言について。
-
C++ vectorに配列をプッシュしたい
-
配列を含む構造体の初期値について
-
VBで構造体の配列を関数に渡す...
-
C言語で特定列だけを抽出して配...
-
キーボードのキー配列について
-
ExcelVBAで質問です。離れた二...
-
2次元配列を戻り値とする関数?
-
unsigned char配列への入力の仕方
-
【C言語】配列の中に配列を入れ...
-
Redimした動的配列はEraseする...
おすすめ情報