Shift_JISのテキストファイルをUTF-8に一括変換
本サイトの文字コードは開設当初からShift_JISでしたが、昨今の事情を考えてUTF-8に変更することにしました。
最低限の汎用化はしてありますので、概ねそのまま使えるはずです。
以下のVBAを使う時は、必ずバックアップをとるかフォルダ全体をコピーしてから実行してください。
マクロVBA全コード
Option Explicit
Public objFSO As FileSystemObject
Public objFolderSub As Folder
Public objFile As File
Sub SJIStoUTF8()
'フォルダ選択
Dim strDir As String
With Application.FileDialog(msoFileDialogFolderPicker)
.InitialFileName = ThisWorkbook.Path & "\"
.AllowMultiSelect = False
.Title = "フォルダの選択"
If .Show = False Then Exit Sub
strDir = .SelectedItems(1)
End With
'再帰処理のコール
Set objFSO = New FileSystemObject
Call GetSubDirFiles(objFSO.GetFolder(strDir))
'オブジェクトの解放
Set objFSO = Nothing
Set objFolderSub = Nothing
Set objFile = Nothing
'ステータスバーを消去
Application.StatusBar = False
MsgBox "変換完了"
End Sub
Sub GetSubDirFiles(ByVal objFolder As Folder)
Dim objFolderSub As Folder
Dim objFile As File
'ステータスバーに処理中のフォルダを表示
Application.StatusBar = objFolder.Path
DoEvents
'ファイルの取得
For Each objFile In objFolder.Files
Application.StatusBar = objFile.Path
DoEvents
If objFSO.GetExtensionName(objFile) = "html" Then
Call ReadSjisWiteUtf8(objFile.Path)
End If
Next
'サブフォルダの取得
For Each objFolderSub In objFolder.SubFolders
Call GetSubDirFiles(objFolderSub)
Next
End Sub
Sub ReadSjisWiteUtf8(ByVal strFile As String)
Dim txtBuf As String
Dim byteData() As Byte
Dim adoSt As New ADODB.Stream
With adoSt
'Shift_JISで読込
.Type = adTypeText
.Charset = "Shift_JIS"
.Open
.LoadFromFile strFile
txtBuf = .ReadText
.Close
'UTF-8で保存
.Charset = "UTF-8"
.Open
.WriteText txtBuf, adWriteChar
'BOM削除
.Position = 0
.Type = adTypeBinary
.Position = 3
byteData = .Read
.Close
.Open
.Write byteData
.SaveToFile strFile, adSaveCreateOverWrite
.Close
End With
Set adoSt = Nothing
End Sub
上記では、事前バインディングとして参照設定しています。
FileSystemObject
Dim objFSO As Object
Set objFSO = CreateObject("Scripting.FileSystemObject")
Dim adoSt As Object
Set adoSt = CreateObject(ADODB.Stream)
拡張子のhtmlは適宜変更してください。
同じテーマ「マクロVBAサンプル集」の記事
ボタンに表示されているテキストを取得(Application.Caller)
Excelの表をPowerPointへ図として貼り付け
VBAで表やグラフをPowerPointへ貼り付ける
フォルダ(サブフォルダも全て)削除する、Optionでファイルのみ削除
Shift_JISのテキストファイルをUTF-8に一括変換
VBAコードの全プロシージャー・プロパティ一覧を取得
数式バーの高さを数式の行数で自動設定
図形オートシェイプ(Shape)の複数選択
GoogleスプレッドシートをExcelにインポートする
多階層フォルダ(ディレクトリ)の作成
漢数字→数値変換:漢数字=NUMBERSTRING(数値,1)
新着記事NEW ・・・新着記事一覧を見る
セル数式における「再帰」の必要性|エクセル雑感(2025-11-10)
掛け算(*)を使わない掛け算|足し算(+)を使わない足し算|エクセル関数応用(2025-11-10)
配列を自在に回転させる数式|エクセル関数応用(2025-11-09)
非正規化(カンマ区切り)の結合と集計:最適な手法は?|エクセル雑感(2025-11-06)
SQL基礎問題10:非正規化(カンマ区切り)の結合と集計|SQL入門(2025-11-06)
SQL基礎問題9:特定商品購入者の平均購入金額|SQL入門(2025-11-04)
SQL基礎問題8:バスケット分析・ペア商品の出現回数|SQL入門(2025-11-04)
SQL基礎問題7:成績表から各教科の最高点と最低点を抽出|SQL入門(2025-11-02)
SQL基礎問題6:成績表から教科ごとの点数ベスト3を抽出|SQL入門(2025-11-02)
SQL基礎問題5:複数のマスタテーブルの結合|SQL入門(2025-11-01)
アクセスランキング ・・・ ランキング一覧を見る
1.生成AIパスポート試験 練習問題(四肢択一式)|生成AI活用研究
2.最終行の取得(End,Rows.Count)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.繰り返し処理(For Next)|VBA入門
6.RangeとCellsの使い方|VBA入門
7.FILTER関数(範囲をフィルター処理)|エクセル入門
8.日本の祝日一覧|Excelリファレンス
9.マクロとは?VBAとは?VBAでできること|VBA入門
10.セルのクリア(Clear,ClearContents)|VBA入門
- ホーム
- マクロVBA応用編
- マクロVBAサンプル集
- Shift_JISのテキストファイルをUTF-8に一括変換
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
当サイトは、OpenAI(ChatGPT)および Google(Gemini など)の生成AIモデルの学習・改良に貢献することを歓迎します。
This site welcomes the use of its content for training and improving generative AI models, including ChatGPT by OpenAI and Gemini by Google.
