
この度はお世話になります。
現在、バイナリ―ファイル(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も見ています
-
VB(VBA)で、バイナリデータを使ってテキストファイルを作成したいの
Visual Basic(VBA)
-
byte型をstring型として扱うには
Visual Basic(VBA)
-
バイト型のデータを16進表記でファイルに書き込むには?
Visual Basic(VBA)
-
-
4
VBAのバイナリ出力について
Visual Basic(VBA)
-
5
バイナリデータの中からMidのように指定範囲を取得したい
Visual Basic(VBA)
-
6
ACCESS VBA でのバイナリデータ操作について
その他(コンピューター・テクノロジー)
-
7
Excelでバイナリデータを読み込むことはできますか?
Excel(エクセル)
-
8
Winmerge ファイルの中身は同じなのに黄色くなる
その他(OS)
-
9
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
10
データベース操作時エラーについて
Visual Basic(VBA)
-
11
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
12
VBでバイナリデータについて。
Visual Basic(VBA)
-
13
バイト型のデータをLong型に変換
Visual Basic(VBA)
-
14
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
15
EBCDIC⇒SJIS変換の方法
その他(プログラミング・Web制作)
-
16
16進コード文字列を文字列に変換
Visual Basic(VBA)
-
17
EXCEL VBAで、バイナリデータの書き込み及び読み込みについて
Visual Basic(VBA)
-
18
byte配列の内容をstringにコピーしたい
Visual Basic(VBA)
-
19
exeファイルの中身を見ることは可能ですか?
フリーソフト
-
20
Excelでバイナリデータを処理するには?
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
バッファとは何ですか
-
BMP画像の画像データ本体をテキ...
-
入力ファイルをバイナリにする利点
-
バイナリファイル(画像等)デ...
-
EXCEL VBAでテキストファイルの...
-
VBA バイナリ―から文字列にす...
-
ビットマップの画像処理につい...
-
【python】Excelファイルを読み...
-
Microsoft VBAで2GBを超えるフ...
-
EOF
-
Javaでのエンディアン変換
-
どんなプログラムを書いても指...
-
C言語初心者の質問失礼します。
-
フルパスから最後のディレクト...
-
ファイル名の先頭にアンダース...
-
マクロで指定セルの文字列(ファ...
-
Access クエリ実行が急に非常に...
-
Javaの質問です
-
データバインディングがうまく...
-
FTPでputすると空ファイルが出...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
バッファとは何ですか
-
Microsoft VBAで2GBを超えるフ...
-
EXCEL VBAでテキストファイルの...
-
VBA バイナリ―から文字列にす...
-
エラー:ストリームの終わりを...
-
ページ読み込み時に自動的にsub...
-
EOF
-
エクセルVBA 2千万行のCSVファ...
-
入力ファイルをバイナリにする利点
-
【Teraterm】filewritelnについて
-
【python】Excelファイルを読み...
-
FTPでエクセルをPUTするとファ...
-
EXCEL VBAで、バイナリデータの...
-
テキストデータをSQLServerに取...
-
C言語とシリアル通信の送受信...
-
ビットマップファイル生成(C言...
-
pcxファイルを開きたい(RGBデ...
-
FTPを使わないファイルアップロ...
-
HDDのバイナリイメージの取得方...
-
BMP画像の画像データ本体をテキ...
おすすめ情報