配列
数回に渡り質問させてもらってますが
構造体のメンバをポインタで宣言してるのが不評で
配列の方でも組んでみました。
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <string.h>
#include <stdio.h>
#include <stdlib.h>
#define TRUE 1
#define FALSE -1
char* get(char **p_str);
char *get_line(char buf[]);
int comp_rtn(const void *p1, const void *p2);
typedef struct {
int number;
char class_type[10];
char name[15];
char subject[10];
int ten;
} my;
my *data;
void myswap(my *p, my *q);
int main(int argc, char* argv[])
{
FILE *fp;
int field = 0, line = 0;
char buf[1000], *str;
char *bufFormat;
char *bufG;
bufFormat =(char *)malloc(1000);
bufG = (char *)malloc(1000);
int line2 = 0;
if((fp=fopen("jjj.txt","r"))==NULL){
printf("ファイルが開けません");
}
while(fgets(buf, 1000, fp) != NULL){
line2++;
}
fclose(fp);
if((fp=fopen("jjj.txt","r"))==NULL){
printf("ファイルが開けません");
}
data = (my *)malloc(sizeof(my) * line2);
while(fgets(buf,1000,fp) != NULL){
bufFormat = get_line(buf);
str = bufFormat;
while(*str != '\0'){
bufG = get(&str);
switch(field){
case 0:
data[line].number = atoi(bufG); break
case 1:
strcpy(data[line].class_type, bufG);
break;
case 2:
strcpy(data[line].name, bufG);
break;
case 3:
strcpy(data[line].subject, bufG);
break;
case 4:
data[line].ten = atoi(bufG);
break;
}
str++;
field++;
}
line++;
field = 0;
}
fclose(fp);
qsort(data,line,sizeof(my),comp_rtn);
for(int m = 0; m < line; m++){
printf("%d\n", data[m].number);
printf("%s\n", data[m].class_type);
printf("%s\n", data[m].name);
printf("%s\n", data[m].subject);
printf("%d\n", data[m].ten);
printf("\n");
}
free(data);
return 0;
}
void myswap(my *p, my *q)
{
my temp;
temp = *p;
*p = *q;
*q = temp;
}
char *get(char **p_str)
{
int i;
char *str;
str = *p_str;
static char bufG[1000];
for(i = 0; *str != ',' && *str != '\0' ; i++){
if(*str == '\n'){
bufG[i] = '\0';
}
else if(*str == '\\'){
str++;
if(*str == 'c'){
bufG[i] = ',';
}
else if(*str == '"'){
bufG[i] = '"';
}
}
else{
bufG[i] = *str;
}
str++;
}
bufG[i] = '\0';
*p_str = str;
return bufG;
}
char *get_line(char buf[])
{
int in_quotation = FALSE, i = 0;
char* str = buf;
static char bufG[1000];
while(*str != '\0'){
if(*str=='"'){
if(in_quotation == TRUE){
str++;
if(*str == '"'){
bufG[i] = '\\';
i++;
bufG[i] = '"';
i++;
}
else{
in_quotation = FALSE;
bufG[i] = *str;
i++;
}
}
else{
in_quotation = TRUE;
}
}
else{
switch(*str){
case '\n':
if(in_quotation == TRUE){
bufG[i] = '\\';
i++;
bufG[i] = 'n';
i++;
}
else{
bufG[i] = *str;
i++;
}
break;
case ',':
if(in_quotation == TRUE){
bufG[i] = '\\';
i++;
bufG[i] = 'c';
i++;
}
else{
bufG[i] = *str;
i++;
}
break;
default:
bufG[i] = *str;
i++;
}
}
str++;
}
bufG[i] = '\0';
return bufG;
}
ファイルは
1,犬,ボルト,国語,2
2,猫,山田,数学,1
3,犬,鈴木,英語,2
4,犬,居合,国語,1
5,猫,伊藤,数学,2
6,猫,斎藤,数学,1
こういう感じになりますが
不思議なことにこのファイルの文字列の所を 表 にすると
バグって表示されます。
例えば
1,表,山田,数学,2とか
1,犬,ボルト,国語,2
2,猫,山田,数学,1
3,犬,鈴木,英語,2
4,犬,居合,国語,1
5,猫,伊藤,表,2
6,猫,斎藤,数学,1
とかです。
この現象は何故起きるのでしょうか?
デバグした所、代入のときにはちゃんとしたものが代入されていますが
次の項目を代入したときにバグ化しているようです
V開発環境はC++6.0のコンソールappです。
お礼
こんにちは。 ご親切なアドバイスをありがとう御座います。 また、こちらからのご挨拶が遅れてしまったことをお許し下さい。 >正規表現で置換してしまうのもありではないかと思います。 正規表現で置換ですか・・。色々なやり方があるのですね。 勉強になります。 >最終的にはデータベースに移行するのが最良の策に思えます。 やはりそうですね。今回の処理を考えている中、やはりDBの利用が望ましい事に改めて気付きました。