質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

1回答

2171閲覧

エクセルに入力されている内容を構造体に代入する方法

lapo

総合スコア15

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2018/11/16 04:26

編集2018/11/16 05:16

下記のエクセル(csvファイル)に入力されている内容を用意した
構造体に読み込みたいのですが、構造体の内容をprintfで出力すると見当違いの文字列がでてきて苦戦しております。
この場合どのようにコードを書けばよいか教えていただけると幸いです・・・。

補足:scanfで1を入力した場合、2行目をtest[0]に格納し、2を入力した場合はtest[1]に格納するような形で書いております
┌────┬──┬───┐
│name │age │blad │1行目ヘッダ情報
├────┼──┼───┤
│yamada 17 │49 │B │2行目
├────┼──┼───┤
│tanaka 12 │40 │B │3行目
├────┼──┼───┤
│satou │ 16 │0 │4行目
└────┴──┴───┘

下記に自身の書いたコードとヘッダー情報を記載いたします。

#include <stdio.h> #include"kadai.h" /*プロトタイプ宣言*/ void Input(INT Number,COMPANY_MEMBER *ShainInfo); INT main(void) { INT key; /* 数値を格納する変数keyを宣言 */ COMPANY_MEMBER Test[2]; scanf("%d",&key); /* scanf関数で入力した数値をkeyに格納 */ Input((key-1),Test);/* input関数を実行 */ printf("%s,%d,%s\n",Test[key].name,Test[key].age,Test[key].blad); return 0; } void Input(INT Number,COMPANY_MEMBER *ShainInfo) { FILE *output; /* (1)ファイルポインタの宣言 */ if ((output = fopen(FILE_PATH, "r")) == NULL) { printf("file open error!!\n"); return; /* エラーの場合は通常、異常終了する */ } fscanf(output,"%s,%d,%s\n",(ShainInfo+Number)->name, (ShainInfo+Number)->age, (ShainInfo+Number)->blad); fclose(output);
#define CHAR char #define UCHAR unsigned char #define SHORT short #define USHORT unsigned short #define INT int #define UINT unsigned int #define FILE_PATH "Kadai3.csv" //サイズ定義 #define NAME_MAX 20 #define BLAD_MAX 3 typedef struct{ CHAR name[NAME_MAX]; // 名前 SHORT age; // 年齢 CHAR blad[BLAD_MAX]; // 血液型 }COMPANY_MEMBER;

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

うまくいかず苦戦しております。

どのようにうまくいかないのか書きましょうね。

気づいた点。

ヘッダーを読み飛ばす処理がない。

Number分読み飛ばす処理がない。

sscanfでageはアドレスを渡す必要があります。

以下、余談です。

FILE *output;

inputでは。

エクセル(csvファイル)

CSVファイルはExcelではありません。
ExcelがCSV形式のファイルを出力しているに過ぎません。

投稿2018/11/16 05:10

ttyp03

総合スコア16998

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

lapo

2018/11/16 05:14

読み飛ばす処理とはどういう意味でしょうか?
ttyp03

2018/11/16 05:18

CSVファイルの1行目はヘッダーなんですよね? fopen直後はファイルの先頭から読み始めますから、ヘッダー行は読み飛ばさないといけません。 同様にNumberで指定している位置までファイルポインタを移動させないといけません。 そういう意味です。
lapo

2018/11/16 05:20

詳しい解説ありがとうございます! たしかにヘッダー行を飛ばす処理を考える必要がありますね・・・。 ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問