私がやりたいことは、オーディオまたはビデオ ファイルからメタデータを取得し、それをデータベース レコードに保存することです。これを行う唯一の方法は、サブプロセスを使用して AVCONV をファイルに保存することです。いくつかの手順を節約するためにこれを行うことができるライブラリはありますか? Pydub または PySox でそれを行う方法が見つかりませんでした。これは、私が使用した、ビットレート、デュレーションなどの情報を変数 audio_info に入れ、メタデータをメタデータに入れる、私が使用した単純化されたハムフィストの初心者コードです。OGG 出力は、私がテストした他の形式とは異なって動作しました (大量のビデオとオーディオでした!)。
try:
p = subprocess.Popen(["avconv" , "-i" , music_file], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
out, err = p.communicate()
retcode = p.wait()
except IOError,e:
pass
extension = uploaded_music_file[-3:]
if "ogg" not in [err , extension]:
if "Metadata:" in err:
list = err.split("Metadata:")
holder = list[1].split("Duration:")
metadata = holder[0]
audio_info = holder[1].replace("At least one output file must be specified","")
print metadata
print audio_info
else:
list = err.split("Duration:")
audio_info = list[1].replace("At least one output file must be specified","")
print "No Metadata"
print audio_info
else:
list = err.split("Duration:")
if "Metadata:" in list[1]:
data = list[1].split("Metadata:")
metadata = data[1].replace("At least one output file must be specified","")
audio_info = data[0]
print metadata
print audio_info
else:
audio_info = list[1].replace("At least one output file must be specified","")
print "No Metadata"
print audio_info
if (audio_info):
print "AUDIO INFO:"
cursor.execute("UPDATE songDB SET audio_info = %s WHERE id = %s" ,[ audio_info , song_id ] )
if (metadata):
print "METADATA:"
cursor.execute("songDB pack_song SET metadata = %s WHERE id = %s" ,[ metadata , song_id ] )