回答編集履歴

5

ソース追記

2019/04/24 03:15

投稿

cateye
cateye

スコア6851

test CHANGED
@@ -17,3 +17,397 @@
17
17
  //
18
18
 
19
19
  全体的にエラーチェックが抜けています。特にファイル操作についてはディスクそのものを壊してしまう可能性も有るのですべてチェックするようにしましょう。
20
+
21
+ 「追記」clang-formatでフォーマットしたものを貼り付けておきます。・・・これがベターではないですが^^;
22
+
23
+ ```c
24
+
25
+ #include <stdio.h>
26
+
27
+ #include <fcntl.h>
28
+
29
+ #include <memory.h>
30
+
31
+ #include <string.h>
32
+
33
+ //#include <io.h>
34
+
35
+ #include <errno.h>
36
+
37
+ #include <math.h>
38
+
39
+ #include <stdlib.h>
40
+
41
+ #include <sys/types.h>
42
+
43
+ #include <sys/stat.h>
44
+
45
+ /*********************************************************************/
46
+
47
+ /* 定数の定義 */
48
+
49
+ /*********************************************************************/
50
+
51
+ #define CR 0x0D
52
+
53
+ #define LF 0x0A
54
+
55
+ #define DATA "SYAIN.DAT"
56
+
57
+ /*********************************************************************/
58
+
59
+ /* 構造体の宣言 */
60
+
61
+ /*********************************************************************/
62
+
63
+ struct syain_k {
64
+
65
+ char sno[5]; /* 社員番号 */
66
+
67
+ char name[20]; /* 氏名 */
68
+
69
+ char salary[7]; /* 給与 */
70
+
71
+ char crlf[2]; /* CR/LF */
72
+
73
+ };
74
+
75
+ /*********************************************************************/
76
+
77
+ /* 静的変数の定義 */
78
+
79
+ /*********************************************************************/
80
+
81
+ /*********************************************************************/
82
+
83
+ /* 内部関数のプロトタイプ宣言 */
84
+
85
+ /*********************************************************************/
86
+
87
+ int numeric_chk(char *str, int n);
88
+
89
+ int search(char *sno, struct syain_k *rec);
90
+
91
+ void data_disp(struct syain_k *rec);
92
+
93
+ void touroku(int recno, char *sno, char *name, char *salary);
94
+
95
+ /*********************************************************************/
96
+
97
+ /* main() メイン関数 */
98
+
99
+ /*********************************************************************/
100
+
101
+ int Fd;
102
+
103
+ initial_syori()
104
+
105
+ {
106
+
107
+ Fd = open(DATA, O_RDWR | O_CREAT, S_IREAD | S_IWRITE);
108
+
109
+ }
110
+
111
+ main()
112
+
113
+ {
114
+
115
+ struct syain_k rdbuf;
116
+
117
+ int a;
118
+
119
+ long d;
120
+
121
+ int recno;
122
+
123
+ char sno[6];
124
+
125
+ char name[21];
126
+
127
+ char salary[8];
128
+
129
+
130
+
131
+ initial_syori();
132
+
133
+ while (1) {
134
+
135
+ printf("社員番号を入力してください\n");
136
+
137
+ scanf("%s", sno);
138
+
139
+ a = numeric_chk(sno, 5);
140
+
141
+ if (a == -1) {
142
+
143
+ printf("NUMERICエラー\n");
144
+
145
+ continue;
146
+
147
+ }
148
+
149
+ d = atol(sno);
150
+
151
+ if (d == 99999L) {
152
+
153
+ return 0;
154
+
155
+ } else if ((d < 1000L) || (d > 90000L)) {
156
+
157
+ printf("範囲エラー\n");
158
+
159
+ continue;
160
+
161
+ }
162
+
163
+ recno = search(sno, &rdbuf);
164
+
165
+ if (recno != 0)
166
+
167
+ data_disp(&rdbuf);
168
+
169
+
170
+
171
+ printf("氏名の入力\n");
172
+
173
+ scanf("%s", name);
174
+
175
+ printf("氏名[%s]\n", name);
176
+
177
+
178
+
179
+ printf("給与を入力してください\n");
180
+
181
+ scanf("%s", salary);
182
+
183
+ a = numeric_chk(salary, 7);
184
+
185
+ if (a == -1) {
186
+
187
+ printf("NUMERICエラー\n");
188
+
189
+ continue;
190
+
191
+ }
192
+
193
+ printf("給与:[%s]\n", salary);
194
+
195
+
196
+
197
+ touroku(recno, sno, name, salary);
198
+
199
+ }
200
+
201
+ }
202
+
203
+ /**************************************l*******************************/
204
+
205
+ /* 数字か文字かのチェック */
206
+
207
+ /* IN: char *str チェックを行う文字列 */
208
+
209
+ /* in: int n チェックを行う文字列のバイト数 */
210
+
211
+ /* 戻り値 0:全て数字: -1:数字以外の文字あり */
212
+
213
+ /*********************************************************************/
214
+
215
+ int numeric_chk(char *str, int n)
216
+
217
+ {
218
+
219
+ int i;
220
+
221
+ for (i = 0; i < n; i++) {
222
+
223
+ if ((str[i] >= '0') && (str[i] <= '9')) {
224
+
225
+ continue;
226
+
227
+ } else {
228
+
229
+ return (-1);
230
+
231
+ }
232
+
233
+ }
234
+
235
+ return 0;
236
+
237
+ }
238
+
239
+ /*********************************************************************/
240
+
241
+ /* レコードの検索処理 */
242
+
243
+ /* IN: *sno キー入力された社員番号 */
244
+
245
+ /* OUT: *rec 社員番号が一致した時の既存レコード */
246
+
247
+ /* 戻り値 0・・・存在しない */
248
+
249
+ /* 1~・・・既存のレコード番号 */
250
+
251
+ /*********************************************************************/
252
+
253
+ int search(char *sno, struct syain_k *rec)
254
+
255
+ {
256
+
257
+ int recno;
258
+
259
+ int n;
260
+
261
+ long a, b;
262
+
263
+ recno = 0;
264
+
265
+
266
+
267
+ a = atol(sno);
268
+
269
+ lseek(Fd, 0L, SEEK_SET);
270
+
271
+ while (1) {
272
+
273
+ n = read(Fd, &rec, sizeof(struct syain_k));
274
+
275
+ b = atol(rec->sno);
276
+
277
+ if (n == 0) {
278
+
279
+ recno = 0;
280
+
281
+ return 0;
282
+
283
+ } else {
284
+
285
+ recno++;
286
+
287
+ if (a == b)
288
+
289
+ printf("P1");
290
+
291
+ getch();
292
+
293
+ return recno;
294
+
295
+ }
296
+
297
+ }
298
+
299
+ }
300
+
301
+ /*********************************************************************/
302
+
303
+ /* 既存データの表示処理 */
304
+
305
+ /* IN: rec 社員番号が一致した時のレコード */
306
+
307
+ /*********************************************************************/
308
+
309
+ void data_disp(struct syain_k *rec) /*表示処理*/
310
+
311
+ {
312
+
313
+ int X;
314
+
315
+ X = atoi(rec->sno);
316
+
317
+ switch (X) {
318
+
319
+ case 0:
320
+
321
+ printf("役員\n");
322
+
323
+ break;
324
+
325
+ case 1:
326
+
327
+ printf("部長\n");
328
+
329
+ break;
330
+
331
+ case 2:
332
+
333
+ printf("課長\n");
334
+
335
+ break;
336
+
337
+ case 3:
338
+
339
+ printf("係長\n");
340
+
341
+ break;
342
+
343
+ case 4:
344
+
345
+ printf("主任\n");
346
+
347
+ break;
348
+
349
+ default:
350
+
351
+ printf(" \n");
352
+
353
+ }
354
+
355
+ printf("%s", rec->name);
356
+
357
+ printf("%s", rec->salary);
358
+
359
+ }
360
+
361
+ /*********************************************************************/
362
+
363
+ /* 登録処理 */
364
+
365
+ /* IN: recno・・・レコード番号 */
366
+
367
+ /* 0:更新レコードは存在しない */
368
+
369
+ /* 1~:更新するレコード番号 */
370
+
371
+ /* IN: *sno・・・社員番号 */
372
+
373
+ /* IN: *name・・・氏名 */
374
+
375
+ /* IN: *salary・・・給与 */
376
+
377
+ /*********************************************************************/
378
+
379
+ void touroku(int recno, char *sno, char *name, char *salary)
380
+
381
+ // char *sno, *name, *salary;
382
+
383
+ {
384
+
385
+ struct syain_k wtbuf;
386
+
387
+ memcpy(wtbuf.sno, sno, 5);
388
+
389
+ memcpy(wtbuf.name, name, 20);
390
+
391
+ memcpy(wtbuf.salary, salary, 7);
392
+
393
+ wtbuf.crlf[0] = CR;
394
+
395
+ wtbuf.crlf[1] = LF;
396
+
397
+ if (recno == 0)
398
+
399
+ lseek(Fd, 0L, SEEK_END);
400
+
401
+ else
402
+
403
+ lseek(Fd, 34 * (recno - 1), SEEK_SET);
404
+
405
+
406
+
407
+ write(Fd, &wtbuf, sizeof(wtbuf));
408
+
409
+ }
410
+
411
+ ```
412
+
413
+ こちらでコンパイラ通すため一部変えています(#include <io.h>のコメント化とか)。・・・エラーが出るので実行ファイルは出来ません^^;

4

追記

2019/04/24 03:15

投稿

cateye
cateye

スコア6851

test CHANGED
@@ -13,3 +13,7 @@
13
13
  ・・あと「このソースコンパイル通ってますか?」
14
14
 
15
15
  case0: printf("役員\n");はcase 0: printf("役員\n");ですね?(他のcaseも)
16
+
17
+ //
18
+
19
+ 全体的にエラーチェックが抜けています。特にファイル操作についてはディスクそのものを壊してしまう可能性も有るのですべてチェックするようにしましょう。

3

加筆

2019/04/24 02:31

投稿

cateye
cateye

スコア6851

test CHANGED
@@ -10,6 +10,6 @@
10
10
 
11
11
  前回の質問でも言いましたが、新旧入り乱れたコーディングです。インデントもいい加減。気をつけましょう。
12
12
 
13
- ・・あと
13
+ ・・あと「このソースコンパイル通ってますか?」
14
14
 
15
15
  case0: printf("役員\n");はcase 0: printf("役員\n");ですね?(他のcaseも)

2

追記

2019/04/24 01:58

投稿

cateye
cateye

スコア6851

test CHANGED
@@ -9,3 +9,7 @@
9
9
  open()やscanf()などエラーチェックがないのは致命的。
10
10
 
11
11
  前回の質問でも言いましたが、新旧入り乱れたコーディングです。インデントもいい加減。気をつけましょう。
12
+
13
+ ・・あと
14
+
15
+ case0: printf("役員\n");はcase 0: printf("役員\n");ですね?(他のcaseも)

1

加筆

2019/04/24 01:55

投稿

cateye
cateye

スコア6851

test CHANGED
@@ -6,4 +6,6 @@
6
6
 
7
7
  //
8
8
 
9
+ open()やscanf()などエラーチェックがないのは致命的。
10
+
9
11
  前回の質問でも言いましたが、新旧入り乱れたコーディングです。インデントもいい加減。気をつけましょう。