项目来源:https://github.com/worldveil/dejavu.git
使用项目前确保正确安装python
安装matplotlib、numpy、wave、MySQLdb、hashlib、pydub、PyAudio、scipy等等,也可以在运行的时候看缺少什么库再去安装。
还有项目中默认的采样率是44100双声道,如果使用其他工具录音可能要注意。
使用3.X可能有如下几点需要注意:
报错:TypeError: Unicode-objects must be encoded before hashing
将fingerprint.py代码作如下修改:
if MIN_HASH_TIME_DELTA <= t_delta <= MAX_HASH_TIME_DELTA:
# h = hashlib.sha1("%s|%s|%s" % (str(freq1),
# str(freq2),
# str(t_delta)))
sha1_str_argument = "%s|%s|%s" % (str(freq1), str(freq2), str(t_delta))
h = hashlib.sha1(sha1_str_argument.encode())
yield (h.hexdigest()[0:FINGERPRINT_REDUCTION], t1)
报错:
Traceback (most recent call last):
File "D:\ProgramData\Anaconda3\lib\site-packages\MySQLdb\cursors.py", line 204, in execute
query = query % args
TypeError: not all arguments converted during bytes formatting
将database_sql中的return_matches方法下的作如下修改
for split_values in grouper(values, 1000): # Create our IN part of the query query = self.SELECT_MULTIPLE mylist = list(split_values) query = query % ', '.join(['UNHEX(%s)'] * len(mylist)) # query = query % ', '.join(['UNHEX(%s)'] * len(list(split_values))) cur.execute(query, mylist) for hash, sid, offset in cur: # (sid, db_offset - song_sampled_offset) yield (sid, offset - mapper[hash])
主要还是因为迭代器和list的转换与使用。
第一次写博客,希望能帮到新手。