主頁(yè) > 知識(shí)庫(kù) > Python對(duì)130w+張圖片檢索的實(shí)現(xiàn)方法

Python對(duì)130w+張圖片檢索的實(shí)現(xiàn)方法

熱門標(biāo)簽:賓館能在百度地圖標(biāo)注嗎 南京crm外呼系統(tǒng)排名 云南地圖標(biāo)注 電銷機(jī)器人 金倫通信 400電話 申請(qǐng) 條件 鄭州智能外呼系統(tǒng)中心 crm電銷機(jī)器人 汕頭電商外呼系統(tǒng)供應(yīng)商 北京外呼電銷機(jī)器人招商

任務(wù)說明:

130w+張圖片,8張excel表里記錄了需要檢索圖片的文件名,現(xiàn)在需要找出對(duì)應(yīng)的圖片,將找出的圖片按不同的excel分別保存,并且在excel里能夠直接打開圖片。

任務(wù)分析:

如果數(shù)據(jù)量不大的話,可以直接讀取excel表里的文件名進(jìn)行搜索保存,但這次的任務(wù)顯然不合適,因?yàn)閳D片實(shí)在太多,所以考慮后按照以下步驟:

1、遍歷圖片文件夾,讀取文件名和文件路徑,寫入到csv文件中;

2、使用pandas的merge函數(shù),實(shí)現(xiàn)8張?jiān)糴xcel表與csv文件根據(jù)圖片文件名的對(duì)碰;

3、使用shutil的copy函數(shù),讀取文件路徑進(jìn)行保存。

代碼分析:

1、文件遍歷

import os
import pandas as pd
 
file_list = []
path_list = []
path = r"此處添加圖片路徑"
print("任務(wù)開始")
for root,dirs,files in os.walk(path):
 for file in files:
  file_list.append(file.split('.')[0])
  path_list.append(os.path.join(root,file))
print("文件遍歷結(jié)束")
file_dic = dict(zip(file_list,path_list))
df = pd.DataFrame.from_dict(file_dic,orient='index', columns=['圖片1路徑']).reset_index().rename(columns={'index':'圖片1'})
df.to_csv("圖片1.csv")
df = pd.DataFrame.from_dict(file_dic,orient='index', columns=['圖片2路徑']).reset_index().rename(columns={'index':'圖片2'})
df.to_csv("圖片2.csv")
df = pd.DataFrame.from_dict(file_dic,orient='index', columns=['圖片3路徑']).reset_index().rename(columns={'index':'圖片3'})
df.to_csv("圖片3.csv")
print("文件目錄導(dǎo)出成功")

2、表格對(duì)碰

import pandas as pd
frame1 = pd.read_excel(r'excel表1.xlsx', 'sheet名')
frame2 = pd.read_csv(r'圖片1.csv', sep=',')
frame3 = pd.read_csv(r'圖片2.csv', sep=',')
frame4 = pd.read_csv(r'圖片3.csv', sep=',')
frame5 = pd.merge(frame1, frame2, on = ['圖片1'], how = 'left')
frame6 = pd.merge(frame5, frame3, on = ['圖片2'], how = 'left')
frame7 = pd.merge(frame6, frame4, on = ['圖片3'], how = 'left')
col = ['圖片1','圖片2','圖片3']
frame7[col] = frame7[col].fillna('未找到')
frame7.to_excel('excel表1合并后.xlsx')

3、圖片復(fù)制

import shutil
target = '此處為excel表1導(dǎo)出圖片路徑'
copylist1 = frame7['圖片1']
for src in copylist1:
  if src != '未找到':
    shutil.copy(src, target)
copylist2 = frame7['圖片2']
for src in copylist2:
  if src != '未找到':
    shutil.copy(src, target)
copylist3 = frame7['圖片3']
for src in copylist3:
  if src != '未找到':
    shutil.copy(src, target)
print('復(fù)制完畢')

4、excel里打開圖片,可以使用excel自帶的hyperlink函數(shù)。

總結(jié)

到此這篇關(guān)于Python對(duì)130w+張圖片檢索實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Python圖片檢索內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 利用Python實(shí)現(xiàn)簡(jiǎn)單的相似圖片搜索的教程
  • 如何利用Python識(shí)別圖片中的文字詳解
  • Python圖片處理之圖片裁剪教程
  • Python批量圖片去水印的方法
  • python 爬取英雄聯(lián)盟皮膚圖片
  • python生成器generator:深度學(xué)習(xí)讀取batch圖片的操作
  • python opencv通過按鍵采集圖片源碼
  • Python如何生成隨機(jī)高斯模糊圖片詳解
  • 使用python如何刪除同一文件夾下相似的圖片
  • Python基于Opencv識(shí)別兩張相似圖片
  • Python圖片檢索之以圖搜圖

標(biāo)簽:石家莊 文山 梅州 錫林郭勒盟 懷化 西寧 昆明 浙江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python對(duì)130w+張圖片檢索的實(shí)現(xiàn)方法》,本文關(guān)鍵詞  Python,對(duì),130w+,張圖片,張,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python對(duì)130w+張圖片檢索的實(shí)現(xiàn)方法》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Python對(duì)130w+張圖片檢索的實(shí)現(xiàn)方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章