
この度はお世話になります。
現在、バイナリ―ファイル(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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
VB(VBA)で、バイナリデータを使ってテキストファイルを作成したいの
Visual Basic(VBA)
-
byte型をstring型として扱うには
Visual Basic(VBA)
-
バイト型のデータを16進表記でファイルに書き込むには?
Visual Basic(VBA)
-
-
4
VBAのバイナリ出力について
Visual Basic(VBA)
-
5
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
6
ACCESS VBA でのバイナリデータ操作について
その他(コンピューター・テクノロジー)
-
7
Winmerge ファイルの中身は同じなのに黄色くなる
その他(OS)
-
8
VBでバイナリデータについて。
Visual Basic(VBA)
-
9
バイナリデータの中からMidのように指定範囲を取得したい
Visual Basic(VBA)
-
10
VBAのコマンドボタンの文字列の改行方法は?
Visual Basic(VBA)
-
11
exeファイルの中身を見ることは可能ですか?
フリーソフト
-
12
EXCEL VBAで、バイナリデータの書き込み及び読み込みについて
Visual Basic(VBA)
-
13
byte配列の内容をstringにコピーしたい
Visual Basic(VBA)
-
14
VBA 変数名に変数を使用したい。
Visual Basic(VBA)
-
15
Excelでバイナリデータを処理するには?
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
= (イコール)で始まるセルの値...
-
エラー:ストリームの終わりを...
-
Microsoft VBAで2GBを超えるフ...
-
EXCEL VBAで、バイナリデータの...
-
Accessからのソケット通信について
-
C言語とシリアル通信の送受信...
-
EOF
-
【python】Excelファイルを読み...
-
ビットマップファイル生成(C言...
-
デバイスファイルに書き込むこと
-
Javaでのエンディアン変換
-
バイナリーデータの一部データ...
-
EXCEL VBAでテキストファイルの...
-
COBOL で組まれたシステムのデ...
-
エクセルVBA 2千万行のCSVファ...
-
Access クエリ実行が急に非常に...
-
どんなプログラムを書いても指...
-
C言語初心者の質問失礼します。
-
Acccess レポートをグループ別...
-
フルパスから最後のディレクト...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
バッファとは何ですか
-
Microsoft VBAで2GBを超えるフ...
-
エラー:ストリームの終わりを...
-
ページ読み込み時に自動的にsub...
-
VBA バイナリ―から文字列にす...
-
EOF
-
入力ファイルをバイナリにする利点
-
EXCEL VBAでテキストファイルの...
-
【python】Excelファイルを読み...
-
関数の容量を知るには?
-
MacからWinにファイルを添付す...
-
= (イコール)で始まるセルの値...
-
BMP画像の画像データ本体をテキ...
-
EXCEL VBAで、バイナリデータの...
-
VC++2010でmecabを使いたい
-
C言語とシリアル通信の送受信...
-
バイナリーデータの一部データ...
-
ファイルをダウンロードして展...
-
JavaScriptの実行速度が遅い
-
wave形式(*.wav)のフォーマット...
おすすめ情報