初めまして。MS VisualStudio 2005を XPで使用しています
VB.netで新規に空のファイルを作成しようとして躓いてしまいました。
やりたい事は、現在の日時が名前になったファイルを作成し、書き込み可能メディアかどうかの判断し、書き込み不可能なメディアの場合処理を終了したいのです。
躓いたのは、ファイルが作れなかった時のエラー処理です。
Try
' hStream が閉じられることを保証するために Try ~ Finally を使用する
Try
' 指定したパスのファイルを作成する
hStream = System.IO.File.Create("C:\Hoge.txt")
Finally
' 作成時に返される FileStream を利用して閉じる
If Not hStream Is Nothing Then
hStream.Close()
End If
End Try
というのがサンプルであったので、自分なりに変更して下記のようにしました。
→ file_name = System.IO.File.Create(f_name)
If file_name Is Nothing Then
MessageBox.Show("やり直して下さい")
file_name.Close()
End If
→の行で「IOExceptionはハンドルされませんでした」とエラーが出ます
色々調べたのですがどう処理を書けばいいのか分かりません。
分かる方がおられましたら、アドバイスを下さい。
No.1ベストアンサー
- 回答日時:
File.Createに失敗したらNothingが返るというのは,どこで得た情報でしょうか。
参考用の実装ソースを見ても,内部的にはFileStreamをnewしているだけですから,Nothingが返ることはあり得ません。
MSDN: File.Create メソッド (String) (System.IO)
http://msdn.microsoft.com/ja-jp/library/d62kzs03 …
失敗した場合に,その場で対応できるのであれば,Try - Catch構文で対処する必要があります。
対応できない場合は,対応できる層でCatchするようにします。
Yune-Kichi様ご回答ありがとうございます。
参考URLも見たのですが、returnValueに値が入った時点でエラーが出るのでどう処理したらいいのか分からなかったです。
if((fpi = fopen(outile,"rb"))==0){
return1;
}
みたいな書き方がVBにもあるのかと思ったのですが分からず困っていました。Yune-Kichiの教えて下さった「Try - Catch構文」なら何とか処理できそうなのでこれからきちんと読んでやってみます
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBAのユーザーフォームのテキストボックスに入力制限をしたい 6 2022/11/15 08:28
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) このVBAでExcelアプリケーションを作成は必要ですか? 3 2023/07/19 21:13
- Visual Basic(VBA) VBA This Workbookモジュールを別ファイルにコピーする方法 1 2022/09/14 01:51
- Visual Basic(VBA) Excel-VBAでのファイルの開き方 4 2023/02/14 11:01
- Visual Basic(VBA) エクセルのマクロについて教えてください。 7 2023/07/04 09:18
- Visual Basic(VBA) 【変更】ファイルを閉じてダイアログで保存した時、更新したシートだけの処理の実行をする 5 2022/03/26 18:31
- Visual Basic(VBA) VBA 参照先で選んだファイルをコピーし、出力先に別名で保存したい 8 2022/05/13 20:37
- Visual Basic(VBA) VBAが止まります。 2 2022/09/02 14:02
- Visual Basic(VBA) 【VBA】印刷マクロのループ処理が反映されません 3 2022/08/09 02:15
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
0バイトのテキストファイル
-
VBAで、JPG写真の撮影日時を読...
-
RPGでメッセージファイル利用
-
VB6.0のメモリリークについて
-
vbaの構文の修正相談(xmlファ...
-
【VBA】印刷マクロのループ処理...
-
Eclipseで検索ができなくなった
-
タスクバーのアイコンについて
-
2GB以上のファイルを扱う方法
-
サイトマップにサブドメインを...
-
ファイル内容を比較する方法
-
PHPからベーシック認証のかかっ...
-
VB2008 iniファイルの全セクシ...
-
【Excel VBA】取り込んだファイ...
-
Javaのファイルダウンロードに...
-
HTMLテキストリンクでExcelファ...
-
VB6 実行ファイルにデータの保存
-
Perlで2GBを超える大きいファイ...
-
BASP21のファイルアップロード...
-
msgget()で指定するkey値について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
0バイトのテキストファイル
-
【Excel VBA】取り込んだファイ...
-
HTMLテキストリンクでExcelファ...
-
VBAで、JPG写真の撮影日時を読...
-
Eclipseで検索ができなくなった
-
vbaの構文の修正相談(xmlファ...
-
2GB以上のファイルを扱う方法
-
サイトマップにサブドメインを...
-
main関数のコマンドライン引数...
-
ファイル更新日取得
-
ファイル作成日時と更新日時を...
-
VB6.0のメモリリークについて
-
C++によるファイル送受信プログ...
-
リソースファイルを認識してく...
-
ファイルのダウンロードが遅い
-
C++.NET 2003 「空のドキュメ...
-
Javaのファイルダウンロードに...
-
HTMLまたはJavaScriptでフ...
-
【VBA】複数CSVの特定範囲を1つ...
-
C#について質問【複数の.datフ...
おすすめ情報