前提・実現したいこと
任意のSignal-to-Noise比の音声波形をPythonで作ろう!
https://engineering.linecorp.com/ja/blog/voice-waveform-arbitrary-signal-to-noise-ratio-python/
こちらのプログラムを実行した所、以下のメッセージが出ました。
これの解決方法を教えていただきたいです。
発生している問題・エラーメッセージ
--------------------------------------------------------------------------- TypeError Traceback (most recent call last) <ipython-input-3-f3a553f9c2cc> in <module> 24 25 if __name__ == '__main__': ---> 26 args = get_args() 27 28 clean_file = args.clean_file <ipython-input-3-f3a553f9c2cc> in get_args() 19 parser.add_argument('--output_noise_file', type=str, default='') 20 parser.add_argument('--output_noisy_file', type=str, default='') ---> 21 parser.add_argument(snr, type=float) 22 args = parser.parse_args() 23 return args ~\anaconda3\lib\argparse.py in add_argument(self, *args, **kwargs) 1345 # argument 1346 chars = self.prefix_chars -> 1347 if not args or len(args) == 1 and args[0][0] not in chars: 1348 if args and 'dest' in kwargs: 1349 raise ValueError('dest supplied twice for positional argument') TypeError: 'int' object is not subscriptable
該当のソースコード
python
1import argparse 2import array 3import math 4import numpy as np 5import random 6import wave 7 8clean_file = 音声ファイル 9noise_file = ノイズファイル 10 11snr = 20 12 13 14def get_args(): 15 parser = argparse.ArgumentParser() 16 parser.add_argument(clean_file, type=str) 17 parser.add_argument(noise_file, type=str) 18 parser.add_argument('--output_clean_file', type=str, default='') 19 parser.add_argument('--output_noise_file', type=str, default='') 20 parser.add_argument('--output_noisy_file', type=str, default='') 21 parser.add_argument(snr, type=float) 22 args = parser.parse_args() 23 return args 24 25if __name__ == '__main__': 26 args = get_args() 27 28 clean_file = args.clean_file 29 noise_file = args.noise_file 30 snr = args.snr 31 32 clean_wav = wave.open(clean_file, "r") 33 noise_wav = wave.open(noise_file, "r")
試したこと
該当サイトに記されているrequired=True等、一部プログラムが異なっていますが、
パスの指定のために外しただけなので特に問題ありません。