for keys, values in vocabList_d.items():
时间: 2024-05-25 17:12:44 浏览: 11
该代码段使用了 Python 中的.items()方法,用于遍历字典(dict)中的键值对。具体来说,该代码段遍历了一个名为vocabList_d的字典,将该字典中的键值对分别赋值给变量keys和values。在遍历过程中,变量keys将依次存储字典中的键(即单词),变量values将依次存储字典中的值(即每个单词在语料库中出现的次数)。这个for循环可以用来统计文本中每个单词的出现次数,生成词汇表等操作。
相关问题
for i in df[0][:15]:#i对15行之前的数据进行遍历(不含第15行) for keys, values in vocabList_d.items():#使用了for循环和字典的items()方法,用于遍历一个字典vocabList_d中的所有键-值对,其中键是词汇表中的单词,值是对应单词的编号 if str(int(i)) == values:# predictors.append(keys) idx.append(int(values))
这段代码主要是将DataFrame中的某一列数据(第0列)转化为词汇表中的单词编号,然后将这些编号存储到一个列表中。具体来说,代码的执行过程如下:
1. 遍历DataFrame中第0列的前15行数据(不含第15行)。
2. 对于每一个遍历到的数据,将其转化为整数,并将其转化为字符串类型(`str(int(i))`)。
3. 在词汇表字典中遍历每一个键-值对,对于每一个键-值对,将其值转化为整数,并将其转化为字符串类型(`str(int(values))`)。
4. 如果字符串类型的数据和字符串类型的键相等(即该单词在词汇表中有对应编号),则将该单词存储到`predictors`列表中,并将该单词的编号存储到`idx`列表中。
最终,`predictors`列表中存储的是DataFrame中第0列数据对应的词汇表中的单词,而`idx`列表中存储的是单词的编号。
def convert_midi(fp): _duration_keys = set() stream = converter.parse(fp) partitions = instrument.partitionByInstrument(stream) # print([(part.getInstrument().instrumentName, len(part.flat.notes)) for part in partitions]) # 获取第一个小节(Measure)中的节拍数 _press_time_dict = defaultdict(list) partition = None for part_sub in partitions: if part_sub.getInstrument().instrumentName.lower() == 'piano' and len(part_sub.flat.notes) > 0: partition = part_sub continue if partition is None: return None, None for _note in partition.flat.notes: _duration = str(_note.duration.quarterLength) if isinstance(_note, NoteClass.Note): _press_time_dict[str(_note.offset)].append([str(_note.pitch), _duration]) _duration_keys.add(_duration) if isinstance(_note, ChordClass.Chord): press_list = _press_time_dict[str(_note.offset)] _duration_keys.add(_duration) for sub_note in _note.notes: press_list.append([str(sub_note.pitch), _duration]) return _press_time_dict, _duration_keys def get_total_keys(_midi_list): _total_keys = set() for _press_time_dict in _midi_list: for step in _press_time_dict.values(): for item in step: _total_keys.add(item[0]) return _total_keys
这段代码的作用是将一个midi文件转换成按键按下的时间和时值的字典,并计算出midi文件中一共用了哪些按键。具体实现过程是:先使用music21库的converter.parse()函数将midi文件解析成Music21 Stream对象,然后使用instrument.partitionByInstrument()函数将Stream对象按照乐器进行分轨,找到钢琴乐器所在的分轨,然后遍历所有音符,按照时间将音符存储在一个字典_press_time_dict中,字典的key为音符的开始时间,value为一个列表,其中每个元素为一个按键和对应的时值;同时记录每个音符的时值,并将这些时值存入一个set集合_duration_keys中。最后使用get_total_keys()函数遍历所有_press_time_dict,将其中出现过的所有按键存储到另外一个set集合_total_keys中,即为midi文件中使用的所有按键。
相关推荐
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![-](https://csdnimg.cn/download_wenku/file_type_column_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)