この度はお世話になります。
現在、バイナリ―ファイル(xxxx.bin)をVBAで読み込み、バイナリ―データを文字列化して、エクセルで解析できるようなシートを作っています。
バイナリ―ファイルの中身が31 39 32 31 ・・・・・となっていたら、31393231・・・と文字列化にしたいです。
そこで、自分でプログラムを考えてみたのですが、バイナリ―が 01 などの場合、など“1”として読み込まれて、“0”が入らず、ずれてしまいます。
Sub 電文解析プログラム()
Dim Deciphering_file As Variant '読み込みファイル
Dim buf As Byte '1バイト格納
Dim fLen As Long 'ファイルサイズ
Dim TEMP(1) As String '
Dim S_JIS As String '文字コード(2バイト)
Dim str As String '文字列データ
Dim i As Long
Deciphering_file = Application.GetOpenFilename("BINファイル(*.bin),*.bin")
fLen = FileLen(Deciphering_file)
Open Deciphering_file For Binary As #1
For i = 1 To fLen
Get #1, i, buf
S_JIS = Hex(buf)
If buf = 0 Then
S_JIS = "00"
End If
TEMP(0) = Mid(S_JIS, 1, 1)
TEMP(1) = Mid(S_JIS, 2, 1)
str = myChr & TEMP(0) & TEMP(1)
Next i
End Sub
ホントは3行くらいで済みそうな気がするんですが、あまりプログラミングをやったことありません。なので、すみませんがご教授お願いいたします。
No.1ベストアンサー
- 回答日時:
「"0" & Hex(buf)」でできる文字列の右側2文字を取ればOKです。
S_JIS = Right("0" & Hex(buf), 2)
"0" & Hex(255) → "0FF"
右側2文字を取ると"FF"
"0" & Hex(5) → "05"
右側2文字を取ると"05"
Picosoft様
ご回答、ご教授ありがとうございます!
回答より、解決いたしました!ありがとうございました。
Right関数も知らなかったので、勉強になりました。
また、なにかあったときはよろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) エクセルのVBAについて とあるサイトのコードを参考に、CSVの文字化けを直すVBAを作成しているの 7 2022/11/04 14:15
- Excel(エクセル) Excelにて、フォルダ内のTextファイルをマクロで統合すると文字化けしてしまう時の解消コード 4 2023/01/01 07:32
- Visual Basic(VBA) ExcelVBAに関する質問 3 2023/02/17 10:47
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- Visual Basic(VBA) 貼り付けた値が消えていく 以下はソースファイルの2番目のシートのB6から最終行を取得 ターゲットファ 2 2023/07/27 12:23
- Visual Basic(VBA) Excel-VBAでのファイルの開き方 4 2023/02/14 11:01
- Visual Basic(VBA) VBAが止まります。 2 2022/09/02 14:02
- Visual Basic(VBA) 別シートから年齢別の件数をカウントしたいの続き 5 2023/01/24 00:16
- Visual Basic(VBA) 実行時エラー´5854´ 文字列型パラメーターが長すぎます。 3 2023/06/08 21:17
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
このQ&Aを見た人はこんなQ&Aも見ています
-
外出時に「待たせる妻」vs イライラする「待つ夫」は日本だけ?見習いたい海外事情
夫の家事参加に積極的なイメージのある海外でも、同様の事例はあるのか。結婚カウンセラーの佐竹悦子さんに伺ってみた。
-
byte型をstring型として扱うには
Visual Basic(VBA)
-
16進コード文字列を文字列に変換
Visual Basic(VBA)
-
VB(VBA)で、バイナリデータを使ってテキストファイルを作成したいの
Visual Basic(VBA)
-
-
4
VBAのバイナリ出力について
Visual Basic(VBA)
-
5
VBA2005 16進を2桁で表示したい。
Visual Basic(VBA)
-
6
EBCDIC⇒SJIS変換の方法
その他(プログラミング・Web制作)
-
7
Microsoft VBAで2GBを超えるファイルサイズのバイナリデータを読み込みたい。
Visual Basic(VBA)
-
8
バイト型のデータを16進表記でファイルに書き込むには?
Visual Basic(VBA)
-
9
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
10
VBAを使って、一部バイナリデータを読み書き
Visual Basic(VBA)
-
11
Excelでバイナリデータを処理するには?
Excel(エクセル)
-
12
Excelでバイナリデータを読み込むことはできますか?
Excel(エクセル)
-
13
エクセル VBA でのCOMポート認識
その他(プログラミング・Web制作)
-
14
EXCEL VBAで、バイナリデータの書き込み及び読み込みについて
Visual Basic(VBA)
-
15
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
16
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
17
2バイト文字をJEFからSJISに変換したい
その他(プログラミング・Web制作)
-
18
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
19
VBAコード記述に際して、コード全体を自動的にインデント付ける方法
Access(アクセス)
-
20
StrConvでUnicodeに変換出来ない文字
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
バッファとは何ですか
-
ページ読み込み時に自動的にsub...
-
画像の保存方法。
-
バイナリファイルの検索について
-
ファイルをダウンロードして展...
-
COBOL で組まれたシステムのデ...
-
エラー:ストリームの終わりを...
-
【MFC】CFileでSeekした位置か...
-
C言語とシリアル通信の送受信...
-
バイナリエディタのつかいかた
-
PHPのfgetcsvの処理容量について
-
htmlのデータをwebページみたい...
-
EXCEL VBAでテキストファイルの...
-
DXFファイル用クラスライブラリ...
-
エンディアンと2の補数表現
-
テキストデータをSQLServerに取...
-
Microsoft VBAで2GBを超えるフ...
-
VB2010 COMポートからのバイナ...
-
VBA バイナリ―から文字列にす...
-
4階調BMPファイルの構成
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
バッファとは何ですか
-
Microsoft VBAで2GBを超えるフ...
-
EXCEL VBAでテキストファイルの...
-
エクセルVBA 2千万行のCSVファ...
-
VBA バイナリ―から文字列にす...
-
ページ読み込み時に自動的にsub...
-
【python】Excelファイルを読み...
-
エラー:ストリームの終わりを...
-
EOF
-
テキストデータをSQLServerに取...
-
MacからWinにファイルを添付す...
-
バイナリエディタのつかいかた
-
リストビュー ⇔ 別ファイル構...
-
入力ファイルをバイナリにする利点
-
24ビットのWaveデータの中身に...
-
FTPでエクセルをPUTするとファ...
-
VB2010 COMポートからのバイナ...
-
バイナリ形式のXMLファイルを読...
-
JavaScriptの実行速度が遅い
-
バッファサイズについて
おすすめ情報