VBA関数
LOF関数

Excelマクロで必須のVBA関数を入門・初級・初心者向けに詳細解説
公開日:2013年5月以前 最終更新日:2025-06-15

LOF関数


LOF関数は、開かれているファイルのサイズ(長さ)をバイト単位で取得するために使用されます。
これにより、ファイル全体のサイズを知ることができ、ファイル操作(読み込みや書き込み)の際に非常に役立ちます。



LOF関数の構文

LOF(filenumber)

filenumber (必須):
データ型: Integer
Open ステートメントで開かれた有効なファイル番号です。

解説・制限事項等
  • LOF 関数は、指定されたfilenumberで開かれているファイルの全長を、バイト単位でLong型の値として返します。
  • この関数は、ファイル内の現在の読み取り/書き込み位置(ファイルポインタ)とは関係なく、ファイルのディスク上での実際のサイズを返します。
  • Input、Output、Append、Random、Binaryのどのモードで開かれたファイルに対しても使用できます。
  • 特にBinaryモードでファイルを読み込む際や、ファイル全体の内容をメモリに読み込む必要がある場合などに、事前にファイルのサイズを知るために頻繁に利用されます。
  • 指定されたfilenumberが有効なファイルとして開かれていない場合、ランタイムエラーが発生します。

LOF関数の使用例

以下のコード例では、LOF 関数を使用して、開かれたファイルのサイズを取得し、メッセージボックスに表示します。

Sub LOF_SimpleSample()

  Dim fileNum As Integer
  Dim filePath As String
  Dim fileSize As Long
  
  filePath = ThisWorkbook.Path & "\LOFTest.txt" ' 一時ファイルパス
  
  On Error GoTo ErrorHandler ' エラーハンドラ設定
  
  ' テストファイルを作成し、内容を書き込む
  fileNum = FreeFile
  Open filePath For Output As #fileNum
  Print #fileNum, "これはテストファイルです。" ' 15バイト + 改行コード
  Close #fileNum
  
  ' ファイルをBinaryモードで開き、LOF関数でサイズを取得して表示
  fileNum = FreeFile
  Open filePath For Binary As #fileNum
  fileSize = LOF(fileNum)
  MsgBox "ファイルのサイズ: " & fileSize & " バイト", vbInformation, "LOF 関数 例"
  Close #fileNum
  
  ' テストファイルを削除
  Kill filePath

  Exit Sub

ErrorHandler:
  MsgBox "エラーが発生しました: " & Err.Description, vbCritical, "エラー"
  If fileNum <> 0 Then Close #fileNum
  If Dir(filePath) <> "" Then Kill filePath
End Sub

  • このコードは、テストファイルを作成し、内容を書き込んだ後、そのファイルをBinaryモードで開いています。
  • LOF(fileNum) を使ってファイルの正確なサイズ(バイト単位)を取得し、メッセージボックスで表示しています。
  • Binaryモードで開くことで、改行コードなども含めたファイルの実際のバイトサイズを正確に取得できます。
  • エラーハンドリングと一時ファイルの削除も含まれています。


※本記事の作成にあたっては、生成AI(Gemini)を活用し一部の文章作成を行っています。最終的な内容は人間による確認・編集を経て掲載しています。


Office VBA リファレンス LOF関数

※VBA関数一覧
マクロVBA関数の一覧と解説です、どんな関数があるかは一度は確認しておくとをお勧めいたします。どんな関数があるだけでも知っておけば、詳細の使い方は実際に使うときに調べても良いでしょう。文字列操作…34 分岐…3 型変換…14 データ判定…10 日付時刻…20 配列…6 ファイル操作…14 数学/財務…28 その他……



同じテーマ「VBA関数」の記事

GetAttr関数
Input関数
Loc関数
LOF関数
Seek関数
Spc関数
Tab関数
Abs関数
Int関数
Fix関数
Hex関数


新着記事NEW ・・・新着記事一覧を見る

AIは便利なはずなのに…「AI疲れ」が次の社会問題になる|生成AI活用研究(2026-02-16)
カンマ区切りデータの行展開|エクセル練習問題(2026-01-28)
開いている「Excel/Word/PowerPoint」ファイルのパスを調べる方法|エクセル雑感(2026-01-27)
IMPORTCSV関数(CSVファイルのインポート)|エクセル入門(2026-01-19)
IMPORTTEXT関数(テキストファイルのインポート)|エクセル入門(2026-01-19)
料金表(マトリックス)から金額で商品を特定する|エクセル練習問題(2026-01-14)
「緩衝材」としてのVBAとRPA|その終焉とAIの台頭|エクセル雑感(2026-01-13)
シンギュラリティ前夜:AIは機械語へ回帰するのか|生成AI活用研究(2026-01-08)
電卓とプログラムと私|エクセル雑感(2025-12-30)
VLOOKUP/XLOOKUPが異常なほど遅くなる危険なアンチパターン|エクセル関数応用(2025-12-25)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.日本の祝日一覧|Excelリファレンス
3.変数宣言のDimとデータ型|VBA入門
4.FILTER関数(範囲をフィルター処理)|エクセル入門
5.RangeとCellsの使い方|VBA入門
6.繰り返し処理(For Next)|VBA入門
7.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
8.マクロとは?VBAとは?VBAでできること|VBA入門
9.セルのクリア(Clear,ClearContents)|VBA入門
10.メッセージボックス(MsgBox関数)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
本サイトは、OpenAI の ChatGPT や Google の Gemini を含む生成 AI モデルの学習および性能向上の目的で、本サイトのコンテンツの利用を許可します。
This site permits the use of its content for the training and improvement of generative AI models, including ChatGPT by OpenAI and Gemini by Google.



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ