質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Bluetooth

Bluetoothとは短距離の間でデータを交換するための無線通信規格である。固定・モバイル両方のデバイスから、短波の電波送信を行うことで、高いセキュリティをもつパーソナルエリアネットワーク(PAN)を構築する。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

Q&A

1回答

1609閲覧

write() argument must be str, not bytes の解決

MinimumMagnum

総合スコア0

Bluetooth

Bluetoothとは短距離の間でデータを交換するための無線通信規格である。固定・モバイル両方のデバイスから、短波の電波送信を行うことで、高いセキュリティをもつパーソナルエリアネットワーク(PAN)を構築する。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

0グッド

0クリップ

投稿2020/12/10 09:45

前提・実現したいこと

1スマホ[Huawei P30]からバグレポートを抽出
2バグレポートからbtsnoopのログを抽出したい
(抽出したログをwiresharkで解析したい)

バグレポートからbtsnoopを抽出する方法:https://source.android.com/devices/bluetooth/verifying_debugging?hl=ja

googleが提供しているスクリプト:
https://android.googlesource.com/platform/system/bt/+/master/tools/scripts/btsnooz.py

参考にしたURL:
https://qiita.com/odkey/items/f924ce56a2f7991274cd

発生している問題・エラーメッセージ

C:\Users\user>python C:\Users\user\Desktop\btsnoop.py C:\Users\user\Desktop\bugreport-xxx-xxx-xxxxxxxxx-xxx-xxxx-xx-xx-xx-xx-xx.txt > btsnoob.log Traceback (most recent call last): File "C:\Users\user\Desktop\btsnoop.py", line 137, in <module> main() File "C:\Users\user\Desktop\btsnoop.py", line 128, in main decode_snooz(base64.standard_b64decode(base64_string)) File "C:\Users\user\Desktop\btsnoop.py", line 69, in decode_snooz decode_snooz_v2(decompressed, last_timestamp_ms) File "C:\Users\user\Desktop\btsnoop.py", line 112, in decode_snooz_v2 sys.stdout.write(struct.pack('>II', packet_length, length)) TypeError: write() argument must be str, not bytes

該当のソースコード

#!/usr/bin/env python2 """ This script extracts btsnooz content from bugreports and generates a valid btsnoop log file which can be viewed using standard tools like Wireshark. btsnooz is a custom format designed to be included in bugreports. It can be described as: base64 { file_header deflate { repeated { record_header record_data } } } where the file_header and record_header are modified versions of the btsnoop headers. """ import base64 import fileinput import struct import sys import zlib # Enumeration of the values the 'type' field can take in a btsnooz # header. These values come from the Bluetooth stack's internal # representation of packet types. TYPE_IN_EVT = 0x10 TYPE_IN_ACL = 0x11 TYPE_IN_SCO = 0x12 TYPE_OUT_CMD = 0x20 TYPE_OUT_ACL = 0x21 TYPE_OUT_SCO = 0x22 def type_to_direction(type): """ Returns the inbound/outbound direction of a packet given its type. 0 = sent packet 1 = received packet """ if type in [TYPE_IN_EVT, TYPE_IN_ACL, TYPE_IN_SCO]: return 1 return 0 def type_to_hci(type): """ Returns the HCI type of a packet given its btsnooz type. """ if type == TYPE_OUT_CMD: return '\x01' if type == TYPE_IN_ACL or type == TYPE_OUT_ACL: return '\x02' if type == TYPE_IN_SCO or type == TYPE_OUT_SCO: return '\x03' if type == TYPE_IN_EVT: return '\x04' def decode_snooz(snooz): """ Decodes all known versions of a btsnooz file into a btsnoop file. """ version, last_timestamp_ms = struct.unpack_from('=bQ', snooz) if version != 1 and version != 2: sys.stderr.write('Unsupported btsnooz version: %s\n' % version) exit(1) # Oddly, the file header (9 bytes) is not compressed, but the rest is. decompressed = zlib.decompress(snooz[9:]) sys.stdout.write('btsnoop\x00\x00\x00\x00\x01\x00\x00\x03\xea') if version == 1: decode_snooz_v1(decompressed, last_timestamp_ms) elif version == 2: decode_snooz_v2(decompressed, last_timestamp_ms) def decode_snooz_v1(decompressed, last_timestamp_ms): """ Decodes btsnooz v1 files into a btsnoop file. """ # An unfortunate consequence of the file format design: we have to do a # pass of the entire file to determine the timestamp of the first packet. first_timestamp_ms = last_timestamp_ms + 0x00dcddb30f2f8000 offset = 0 while offset < len(decompressed): length, delta_time_ms, type = struct.unpack_from('=HIb', decompressed, offset) offset += 7 + length - 1 first_timestamp_ms -= delta_time_ms # Second pass does the actual writing out to stdout. offset = 0 while offset < len(decompressed): length, delta_time_ms, type = struct.unpack_from('=HIb', decompressed, offset) first_timestamp_ms += delta_time_ms offset += 7 sys.stdout.write(struct.pack('>II', length, length)) sys.stdout.write(struct.pack('>II', type_to_direction(type), 0)) sys.stdout.write(struct.pack('>II', (first_timestamp_ms >> 32), (first_timestamp_ms & 0xFFFFFFFF))) sys.stdout.write(type_to_hci(type)) sys.stdout.write(decompressed[offset:offset + length - 1]) offset += length - 1 def decode_snooz_v2(decompressed, last_timestamp_ms): """ Decodes btsnooz v2 files into a btsnoop file. """ # An unfortunate consequence of the file format design: we have to do a # pass of the entire file to determine the timestamp of the first packet. first_timestamp_ms = last_timestamp_ms + 0x00dcddb30f2f8000 offset = 0 while offset < len(decompressed): length, packet_length, delta_time_ms, snooz_type = struct.unpack_from('=HHIb', decompressed, offset) offset += 9 + length - 1 first_timestamp_ms -= delta_time_ms # Second pass does the actual writing out to stdout. offset = 0 while offset < len(decompressed): length, packet_length, delta_time_ms, snooz_type = struct.unpack_from('=HHIb', decompressed, offset) first_timestamp_ms += delta_time_ms offset += 9 sys.stdout.write(struct.pack('>II', packet_length, length)) sys.stdout.write(struct.pack('>II', type_to_direction(snooz_type), 0)) sys.stdout.write(struct.pack('>II', (first_timestamp_ms >> 32), (first_timestamp_ms & 0xFFFFFFFF))) sys.stdout.write(type_to_hci(snooz_type)) sys.stdout.write(decompressed[offset:offset + length - 1]) offset += length - 1 def main(): if len(sys.argv) > 2: sys.stderr.write('Usage: %s [bugreport]\n' % sys.argv[0]) exit(1) iterator = fileinput.input() found = False base64_string = "" for line in iterator: if found: if line.find('--- END:BTSNOOP_LOG_SUMMARY') != -1: decode_snooz(base64.standard_b64decode(base64_string)) sys.exit(0) base64_string += line.strip() if line.find('--- BEGIN:BTSNOOP_LOG_SUMMARY') != -1: found = True if not found: sys.stderr.write('No btsnooz section found in bugreport.\n') sys.exit(1) if __name__ == '__main__': main()

試したこと

bytesをstrに変換する方法を検索したのですがやり方がわかりませんでした、、

補足情報(FW/ツールのバージョンなど)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

TLDR: try running python2 instead of python3

Hi there,

I ran into this issue as well, and you're the only other person I found suffering from it on Google :)

I realized after there are 2 version of python and I was running btsnooz on python3.
Running with python2 worked!

I hope that helps you, and I filed a bug to ask for a script, or update documentation.

Cheers,
Licryle

PS: sorry my reply is in english!

投稿2020/12/24 19:31

licryle

総合スコア2

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問