## windows程式圖標緩存 在vs中替換c++程式的圖標後,需要重新編譯,但是很多情況下都不會刷新,還是看到老的圖標,只能重啟電腦才能看到新的圖標。 通過ChatGPT得到相關的回答如下: 如果在 Windows 上更換了可執行文件 (.exe) 的圖標,但是在圖標文件已經更改的情況下仍然顯示 ...
windows程式圖標緩存
在vs中替換c++程式的圖標後,需要重新編譯,但是很多情況下都不會刷新,還是看到老的圖標,只能重啟電腦才能看到新的圖標。
通過ChatGPT得到相關的回答如下:
如果在 Windows 上更換了可執行文件 (.exe) 的圖標,但是在圖標文件已經更改的情況下仍然顯示舊的圖標,可能是因為 Windows 緩存了舊的圖標。為瞭解決這個問題,可以嘗試以下步驟:
-
從可執行文件的圖標屬性中刪除圖標,保存並關閉。
-
重新打開文件的屬性對話框,選擇 "更改圖標"。
-
選擇一個新的圖標並保存更改。
-
如果圖標仍然沒有更改,請嘗試重啟 Windows Explorer 進程。可以在任務管理器中找到 "Windows Explorer" 進程,右鍵單擊並選擇 "重啟"。
-
如果問題仍然存在,嘗試清除 Windows 圖標緩存。可以按照上一個問題中提到的步驟進行操作。 一般情況下,以上步驟應該可以解決更換圖標後仍然顯示舊圖標的問題。
但是以上方法都相對比較麻煩,那麼有沒有更好的方法來確認圖標是否更換成功呢?
IconViewer
下載地址:Download IconViewer - MajorGeeks
使用方法
下載安裝後,需要重啟電腦才能生效,註意一定要重啟電腦才能生效。
選擇exe - 滑鼠右鍵 - 屬性 - 會增加一欄 icon,顯示exe的圖標。
icon製作方法
windows應用程式的圖標文件製作
原理:把不同尺寸的png合在一個ico文件中
下載Greenfish Icon Editor Pro 4.2,與老版本的操作方式類似,有多個圖層,註意不同的尺寸只需要一個圖層即可。
可以保存工程為模版,下次從模版中修改即可。
python腳本提取icon
從網上找到一段python腳本提取exe程式的圖標,python2與3理論上都可以使用。
# -*- coding: GB18030 -*-
import os
import sys
import string
import pefile
import hashlib
import struct
def get_ico(argv_dic, group_dic):
totalData, lastData, lastIconId = '', None, -1
if group_dic[0]:
resIcons = filter(lambda x: x.id==pefile.RESOURCE_TYPE['RT_ICON'], argv_dic['peobj'].DIRECTORY_ENTRY_RESOURCE.entries)
idCount = struct.unpack('H', group_dic[0][4:6])[0]
iconIds = set([struct.unpack('H', group_dic[0][i*14+18:i*14+20])[0] for i in xrange(idCount)])
iconIdMap = dict([(struct.unpack('H', group_dic[0][i*14+18:i*14+20])[0], i) for i in xrange(idCount)])
for resIcon in resIcons:
if resIcon and hasattr(resIcon, 'directory'):
for resId in resIcon.directory.entries:
if resId.id in iconIds:
lastIconId = resId.id
if hasattr(resId, 'directory'):
for resLang in resId.directory.entries:
lastData = argv_dic['peobj'].get_data(resLang.data.struct.OffsetToData, resLang.data.struct.Size)
if iconIdMap.has_key(resId.id) == False:
continue
iconIdx = iconIdMap[resId.id]
iconHeader = '\x00\x00\x01\x00\x01\x00' + group_dic[0][6 + iconIdx * 14:6 + iconIdx * 14 + 12] + '\x16\x00\x00\x00'
lastData = iconHeader + lastData
totalData = totalData + lastData
else:
lastData = argv_dic['peobj'].get_data(resId.data.struct.OffsetToData, resId.data.struct.Size)
iconIdx = iconIdMap[resId.id]
iconHeader = '\x00\x00\x01\x00\x01\x00' + group_dic[0][6 + iconIdx * 14:6 + iconIdx * 14 + 12] + '\x16\x00\x00\x00'
lastData = iconHeader + lastData
totalData = totalData + lastData
md5obj = hashlib.md5()
md5obj.update(totalData)
path_filter = os.path.join(argv_dic['outdir'], md5obj.hexdigest())
if os.path.exists(path_filter) == False:
os.mkdir(path_filter)
if argv_dic['if_makeico'] != 0:
os.mkdir(os.path.join(path_filter, "ico"))
for resIcon in resIcons:
if resIcon and hasattr(resIcon, 'directory'):
for resId in resIcon.directory.entries:
if resId.id in iconIds:
lastIconId = resId.id
if hasattr(resId, 'directory'):
for resLang in resId.directory.entries:
lastData = argv_dic['peobj'].get_data(resLang.data.struct.OffsetToData, resLang.data.struct.Size)
if iconIdMap.has_key(resId.id) == False:
continue
iconIdx = iconIdMap[resId.id]
iconHeader = '\x00\x00\x01\x00\x01\x00' + group_dic[0][6 + iconIdx * 14:6 + iconIdx * 14 + 12] + '\x16\x00\x00\x00'
lastData = iconHeader + lastData
md5obj = hashlib.md5()
md5obj.update(lastData[22:])
file_ico = open(os.path.join(path_filter, "ico", md5obj.hexdigest() + ".ico"), "wb+")
file_ico.write(lastData)
file_ico.close()
print("hash.md5(pe.resources[i].offset, pe.resources[i].length) == \""+md5obj.hexdigest()+ "\" or")
else:
lastData = argv_dic['peobj'].get_data(resId.data.struct.OffsetToData, resId.data.struct.Size)
iconIdx = iconIdMap[resId.id]
iconHeader = '\x00\x00\x01\x00\x01\x00' + group_dic[0][6 + iconIdx * 14:6 + iconIdx * 14 + 12] + '\x16\x00\x00\x00'
lastData = iconHeader + lastData
file_ico = open(os.path.join(path_filter, "ico", md5obj.hexdigest() + ".ico"), "wb+")
file_ico.write(lastData)
file_ico.close()
print("hash.md5(pe.resources[i].offset, pe.resources[i].length) == \""+md5obj.hexdigest()+ "\" or")
argv_dic['peobj'].close()
os.rename(argv_dic['path_sample'], os.path.join(path_filter, os.path.basename(argv_dic['path_sample']) + ".exe"))
return True
argv_dic['peobj'].close()
def scan_ico(path_sample, outdir, if_makeico):
peobj = pefile.PE(path_sample)
group_dic = {}
if hasattr(peobj, 'DIRECTORY_ENTRY_RESOURCE'):
resGroupIcon = filter(lambda x: x.id==pefile.RESOURCE_TYPE['RT_GROUP_ICON'], peobj.DIRECTORY_ENTRY_RESOURCE.entries)
if len(resGroupIcon) > 0:
for i in range(len(resGroupIcon)):
resGroupIcon = resGroupIcon[i]
if hasattr(resGroupIcon, 'directory'):
for resId in resGroupIcon.directory.entries:
if hasattr(resId, 'directory'):
for resLang in resId.directory.entries:
group_dic[0] = peobj.get_data(resLang.data.struct.OffsetToData, resLang.data.struct.Size)
return get_ico({'peobj':peobj, 'outdir':outdir, 'path_sample':path_sample, 'if_makeico':if_makeico}, group_dic)
else:
group_dic[0] = peobj.get_data(resId.data.struct.OffsetToData, resId.data.struct.Size)
return get_ico({'peobj':peobj, 'outdir':outdir, 'path_sample':path_sample, 'if_makeico':if_makeico}, group_dic)
else:
peobj.close()
else:
peobj.close()
else:
peobj.close()
def plan():
#這裡你可傳參,我先幫你寫死了
if len(sys.argv) > 1:
path_sample = sys.argv[1]
if len(sys.argv) > 2:
outdir = sys.argv[2]
if len(sys.argv) > 3:
if_makeico = int(sys.argv[3])
if_sucess = False
try:
path_sample = r"D:\xx\xx.exe"#也可以指定一個完整的路徑
outdir = "./"
if_makeico = 1
if_sucess = scan_ico(path_sample, outdir, if_makeico)
except Exception,e:
if str(e).find("Error") != -1:
print path_sample + " scan ico failed."
return
if if_sucess != True:
os.rename(path_sample, os.path.join(outdir, "no_find_ico", os.path.basename(path_sample) + ".exe"))
if __name__ == '__main__':
plan() #任務開始