for i, name in enumerate(table5_column_lst[1:]): table5.loc[i+1, name] = adhesive_df.loc[:, (adhesive_df.loc[0] == table5_column_lst[i]) & (adhesive_df.loc[1] == lst[i])] ValueError: Incompatible indexer with DataFrame
时间: 2024-03-11 22:47:52 浏览: 156
这个错误通常是因为尝试使用不兼容的索引器访问 Pandas DataFrame 数据而引起的。在这个代码片段中,`adhesive_df.loc[0]` 和 `adhesive_df.loc[1]` 似乎是在尝试访问 `adhesive_df` 的第 1 行和第 2 行。但是,这种索引方式可能不适用于 `adhesive_df`,因为这个 DataFrame 的索引可能是默认的整数索引,而不是 MultiIndex 对象。
如果您的目的只是从 `adhesive_df` 中选择特定的列,您可以尝试使用以下代码:
```
for i, name in enumerate(table5_column_lst[1:]):
table5.loc[i+1, name] = adhesive_df[name][(adhesive_df.iloc[0] == table5_column_lst[i]) & (adhesive_df.iloc[1] == lst[i])].values
```
在这个代码中,我们使用了 `iloc` 属性来访问第一行和第二行,而使用列名 `name` 来获取需要的列。然后,我们使用布尔索引来选择需要的行。最后,我们使用 `.values` 将结果转换为 NumPy 数组,以便可以将其添加到 `table5` DataFrame。
如果这个方法不能解决问题,您可以提供更多的上下文和代码示例,以便我能够更好地理解问题。
相关问题
def evaluate(self, datloader_Test): Image_Feature_ALL = [] Image_Name = [] Sketch_Feature_ALL = [] Sketch_Name = [] start_time = time.time() self.eval() for i_batch, sampled_batch in enumerate(datloader_Test): sketch_feature, positive_feature = self.test_forward(sampled_batch) Sketch_Feature_ALL.extend(sketch_feature) #草图特征 模型的 Sketch_Name.extend(sampled_batch['sketch_path']) #草图名 for i_num, positive_name in enumerate(sampled_batch['positive_path']): #遍历正例图像 if positive_name not in Image_Name: Image_Name.append(positive_name) Image_Feature_ALL.append(positive_feature[i_num]) rank = torch.zeros(len(Sketch_Name)) Image_Feature_ALL = torch.stack(Image_Feature_ALL) Image_Feature_ALL = Image_Feature_ALL.view(Image_Feature_ALL.size(0), -1) for num, sketch_feature in enumerate(Sketch_Feature_ALL): s_name = Sketch_Name[num] sketch_query_name = os.path.basename(s_name) # 提取草图路径中的文件名作为查询名称 position_query = -1 for i, image_name in enumerate(Image_Name): if sketch_query_name in os.path.basename(image_name): # 提取图像路径中的文件名进行匹配 position_query = i break if position_query != -1: sketch_feature = sketch_feature.view(1, -1) distance = F.pairwise_distance(sketch_feature, Image_Feature_ALL) target_distance = F.pairwise_distance(sketch_feature, Image_Feature_ALL[position_query].view(1, -1)) rank[num] = distance.le(target_distance).sum() top1 = rank.le(1).sum().item() / rank.shape[0] top10 = rank.le(10).sum().item() / rank.shape[0] print('Time to Evaluate: {}'.format(time.time() - start_time)) return top1, top10
这是一个evaluate函数的更新版本。在这个版本中,函数接受一个datloader_Test参数,该参数是一个数据加载器,用于加载测试数据集。
首先,函数初始化一些变量,包括用于存储图像特征、图像名称、草图特征和草图名称的列表。然后,函数将模型设置为评估模式。
接下来,函数遍历测试数据集中的每个批次。对于每个批次,函数调用test_forward方法获取草图特征和正样本特征,并将它们分别添加到相应的列表中。同时,函数还将正样本的路径添加到图像名称列表中。
然后,函数遍历所有的草图特征,并根据草图路径提取查询名称。然后,函数在图像名称列表中查找与查询名称匹配的索引,并将其赋值给position_query变量。
接下来,如果position_query不等于-1,则说明找到了与查询名称匹配的正样本图像。函数使用F.pairwise_distance计算草图特征与所有正样本特征之间的距离,并使用F.pairwise_distance计算草图特征与对应正样本特征之间的距离。
然后,函数计算每个草图与所有正样本之间的排序值,并统计排名在前1和前10的比例。
最后,函数打印评估时间,并返回top1和top10的比例。
请注意,这只是代码的一个简单解释,具体实现可能还涉及其他细节。
def evaluate(self, datloader_Test): Image_Feature_ALL = [] Image_Name = [] Sketch_Feature_ALL = [] Sketch_Name = [] start_time = time.time() self.eval() for i_batch, sanpled_batch in enumerate(datloader_Test): sketch_feature, positive_feature= self.test_forward(sanpled_batch) Sketch_Feature_ALL.extend(sketch_feature) Sketch_Name.extend(sanpled_batch['sketch_path']) for i_num, positive_name in enumerate(sanpled_batch['positive_path']): if positive_name not in Image_Name: Image_Name.append(sanpled_batch['positive_path'][i_num]) Image_Feature_ALL.append(positive_feature[i_num]) rank = torch.zeros(len(Sketch_Name)) Image_Feature_ALL = torch.stack(Image_Feature_ALL) for num, sketch_feature in enumerate(Sketch_Feature_ALL): s_name = Sketch_Name[num] sketch_query_name = '_'.join(s_name.split('/')[-1].split('_')[:-1]) position_query = Image_Name.index(sketch_query_name) distance = F.pairwise_distance(sketch_feature.unsqueeze(0), Image_Feature_ALL) target_distance = F.pairwise_distance(sketch_feature.unsqueeze(0), Image_Feature_ALL[position_query].unsqueeze(0)) rank[num] = distance.le(target_distance).sum() top1 = rank.le(1).sum().numpy() / rank.shape[0] top10 = rank.le(10).sum().numpy() / rank.shape[0] print('Time to EValuate:{}'.format(time.time() - start_time)) return top1, top10
这段代码是一个evaluate函数,用于评估模型在测试数据集上的性能。函数接受一个datloader_Test参数,该参数是一个数据加载器,用于加载测试数据集。
函数首先初始化一些变量,包括用于存储图像特征、图像名称、素描特征和素描名称的列表。然后,函数将模型设置为评估模式。
接下来,函数遍历测试数据集中的每个批次。对于每个批次,函数调用test_forward方法获取素描特征和正样本特征,并将它们分别添加到相应的列表中。同时,函数还将正样本的路径添加到图像名称列表中。
然后,函数遍历所有的素描特征,并根据素描路径推断出对应的正样本路径,并在图像名称列表中查找该路径所对应的索引。然后,函数使用F.pairwise_distance计算素描特征与所有正样本特征之间的距离,并使用F.pairwise_distance计算素描特征与对应正样本特征之间的距离。
接下来,函数计算每个素描与所有正样本之间的排序值,并统计排名在前1和前10的比例。
最后,函数打印评估时间,并返回top1和top10的比例。
请注意,这只是代码的一个简单解释,具体实现可能还涉及其他细节。
阅读全文