回答編集履歴

2

補足を追加

2019/06/27 09:01

投稿

magichan
magichan

スコア15898

test CHANGED
@@ -168,6 +168,8 @@
168
168
 
169
169
 
170
170
 
171
+ # 0~1 秒のデータを表示
172
+
171
173
  t = np.arange(0, 1., 1/sample_rate)
172
174
 
173
175
  fig, axs = plt.subplots(2,1)

1

実データを元に追記

2019/06/27 09:01

投稿

magichan
magichan

スコア15898

test CHANGED
@@ -51,3 +51,133 @@
51
51
 
52
52
 
53
53
  で良いかと思います。
54
+
55
+
56
+
57
+ ---
58
+
59
+ ##【追記】
60
+
61
+ > データを提示していただいたので。
62
+
63
+
64
+
65
+ とりあえず以下のようにWAVのデータ部のみをfloat32にて読み込み、int16 に変換してみたところ問題なく再生できているようです。
66
+
67
+ (データの開始位置 (0x58) は実データをバイナリエディタで解析した値を直打ちしております。)
68
+
69
+
70
+
71
+ ```Python
72
+
73
+ import pyaudio
74
+
75
+ import struct
76
+
77
+ import numpy as np
78
+
79
+
80
+
81
+ with open('faucet_1.wav', 'rb') as f:
82
+
83
+ buf = f.read()[0x58:]
84
+
85
+
86
+
87
+ channel_num = 2
88
+
89
+ sample_rate = 44100
90
+
91
+
92
+
93
+ data = np.frombuffer(buf, dtype='float32')
94
+
95
+
96
+
97
+ # 2バイトデータに変換して再生してみる
98
+
99
+ sample_width = 2
100
+
101
+ data = [int(d * 32767.0) for d in data]
102
+
103
+ data = struct.pack('h' * len(data), *data)
104
+
105
+
106
+
107
+ audio = pyaudio.PyAudio()
108
+
109
+ stream = audio.open(format=audio.get_format_from_width(sample_width),
110
+
111
+ channels=channel_num,
112
+
113
+ rate=sample_rate,
114
+
115
+ output=True)
116
+
117
+
118
+
119
+ chunk = 1024
120
+
121
+ pos = 0
122
+
123
+ while data != '':
124
+
125
+ stream.write(data[pos:pos+chunk])
126
+
127
+ pos += chunk
128
+
129
+ stream.close()
130
+
131
+
132
+
133
+ audio.terminate()
134
+
135
+ ```
136
+
137
+
138
+
139
+ 今回の質問はデータを読み込みたいということでしたので、データを表示するとなるとこんな感じになるかと思います。
140
+
141
+
142
+
143
+ ```Python
144
+
145
+ import numpy as np
146
+
147
+ import matplotlib.pyplot as plt
148
+
149
+
150
+
151
+ with open('faucet_1.wav', 'rb') as f:
152
+
153
+ buf = f.read()[0x58:]
154
+
155
+
156
+
157
+ channel_num = 2
158
+
159
+ sample_rate = 44100
160
+
161
+
162
+
163
+ data = np.frombuffer(buf, dtype='float32')
164
+
165
+ l_data = data[0::2]
166
+
167
+ r_data = data[1::2]
168
+
169
+
170
+
171
+ t = np.arange(0, 1., 1/sample_rate)
172
+
173
+ fig, axs = plt.subplots(2,1)
174
+
175
+ axs[0].plot(t, l_data[:len(t)])
176
+
177
+ axs[1].plot(t, r_data[:len(t)])
178
+
179
+ plt.show()
180
+
181
+
182
+
183
+ ```