
No.2ベストアンサー
- 回答日時:
・簡単なやり方
新しいファイルを作って、挿入位置より前のデータを元ファイルからコピー、挿入データを追記、挿入位置より後のデータを元ファイルからコピーする。元ファイルを消して新しいファイルをリネームすれば完了。
・上記では空きディスク容量が足りないとき
挿入位置より後のデータを挿入データ分だけ後ろに移動して空いた位置に挿入データを書き込む。データの移動は上書きしないように後ろから順にコピーするなど手順は面倒だが出来ないことではない。
なお性能は考慮してませんので。後者の方法をとらなければいけないほど大きなファイルなら途中挿入が必要にならないデータ構造の検討から始めるべきでしょう。
なるほど。後者は特にギミックなやり方ですね。
やはり、データ構造にポイントがあるようなので、その辺の考え方も勉強していこうと思います。
ありがとうございました。
No.3
- 回答日時:
可能であるなら、ファイルへの書き込みはデータが完成してから一気に書いた方が無難です。
そうしないと、中途半端にファイルに書き込んでから、途中でエラーや例外が発生した場合に、いろいろと面倒が起こります。
データが完成してからなら、I/Oエラー以外で中途半端なファイルができる可能性はありません。
もちろん、今回のように途中にデータを挿入したり、一部分を削除することも、メモリ上で行えば簡単です。
ありがとうございます。
そうですよね。そういえばソフトを使ってファイル開くとその文だけメモリも食っているので、いったん全部も見込んで処理しているのですよね。
No.1
- 回答日時:
全部はじめから読み込んで、必要なところにデータを追加して、別のファイル名で書き戻します。
後は、必要なら元のファイル名を変更するか削除し、変更したファイル名を元のものに変更します。全部読み込むことがストレスとなるようなファイルの場合は、ランダムファイル等のデータ構造を考える必要があるでしょう。
なるほど、やっぱりすべて新しいものに移すのですね。
結構ストレスのかかるものなので、何か技があるのかと思いましたが、その技はデータ構造の検討にあるようですね。
これからデータ構造を考えるような勉強もしていこうと思います。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
ファイル書込みで一行もしくは部分的に上書きする
PHP
-
ファイル内のデータを1行削除する方法
C言語・C++・C#
-
C言語での引数の省略方法
C言語・C++・C#
-
-
4
C言語で、メモリを解放しないで終わるプログラム
C言語・C++・C#
-
5
C言語 ファイルの指定された行を表示
C言語・C++・C#
-
6
【MFC】CFileでSeekした位置から値出力したい
C言語・C++・C#
-
7
配列を使わずに、変数名を動的にループで回したい
C言語・C++・C#
-
8
【C言語】テキストファイル内のデータを一行削除
C言語・C++・C#
-
9
C++でのCRLFについて
C言語・C++・C#
-
10
C 開放してるのにエラー(double free or corruption (!prev))がでる
C言語・C++・C#
-
11
【C言語】全角文字の配列を、全角のまま1文字ずつ出力する方法
C言語・C++・C#
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【Excel】[Expression.Error] ...
-
VBAでCSVファイルが使用中かど...
-
【アクセス】「ほかのユーザー...
-
共有フォルダに誰が何にアクセ...
-
拡張子が「cda」のファイルを聞...
-
特定のエクセルファイルを起動...
-
社内Excel共有ブックでの保存ト...
-
Batch: フォルダ内の特定のファ...
-
事務の派遣で働いています。多...
-
access関数を説明できる方いま...
-
Dream weaverで、誤ってファイ...
-
excelを共有ファイルにすると行...
-
(Excelマクロ)datファイルをエ...
-
月が変わったら自動でシートが...
-
相手のPCにVBAからメッセ...
-
WEBクエリが使えない場合のHPデ...
-
vbsでゴミ箱への移動
-
AccessVBAで作成したExcelファ...
-
Excel VBA 処理後データが重た...
-
『ファイルの上書きの確認』ダ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【Excel】[Expression.Error] ...
-
特定のエクセルファイルを起動...
-
Batch: フォルダ内の特定のファ...
-
共有フォルダに誰が何にアクセ...
-
excelを共有ファイルにすると行...
-
社内Excel共有ブックでの保存ト...
-
AccessVBAで作成したExcelファ...
-
事務の派遣で働いています。多...
-
VBAでCSVファイルが使用中かど...
-
拡張子が「cda」のファイルを聞...
-
Access VBA を利用して、フォル...
-
(Excelマクロ)datファイルをエ...
-
【VBA】異なる行だけを抜き出す...
-
【アクセス】「ほかのユーザー...
-
Excel VBA 処理後データが重た...
-
相手のPCにVBAからメッセ...
-
access関数を説明できる方いま...
-
XMLデータを変換し印刷する方法
-
WEBクエリが使えない場合のHPデ...
-
メールで送られてきたワードの...
おすすめ情報