Office 板


LINE

軟體:OFFICE 365 EXCEL 版本:1908 目前正在編寫的功能是直接把一個工作表當成暗號表 A欄=暗號,B欄=解碼後的對應詞 另一個工作表則是雜亂無章的暗號跟解碼後的詞彙 然後要用暗號表去抓出文章內是否有出現暗號 而且是否解碼後的詞彙是否是正確的 例如 暗號表 A1=9527 B1=唐伯虎 A2=88 B2=掰掰 (下略) 解碼表 A1=pppij"9527"clizxj B1=pppij"唐伯X"clizxj C1=解碼偵錯:出現暗號:9527 解碼遺漏:唐伯虎 大概是這種感覺 目前編寫的代碼大致如下: For Row1 = 2 To 10000 For Row2 = 4 To 10000 Sheets("解碼").Activate If Sheets("暗號").Cells(Row1, 1).value <> "" Then If Sheets("解碼").Cells(Row2, 1).value <> "" Then Code = Sheets("暗號").Cells(Row1, 1).value '暗號 Decry = Sheets("暗號").Cells(Row1, 2).value '解碼對應詞 Decode1 = InStr(1, (Cells(Row2, 1)), Code) '判斷暗號文章是否有暗號 Decode2 = InStr(1, (Cells(Row2, 2)), Decry) '判斷解碼後是否有對應詞 If Decode1 <> 0 And Decode2 = 0 Then '若暗號文章有暗號但解碼後無對應詞 For Col = 7 To 52 If Cells(Row2, Col).value = "" Then Cells(Row2, Col).value = "解碼遺漏:" & Decry '在該文章列的7~52欄個別記下解碼遺漏的對應詞(因為可能一格內有多個不同暗號) Exit For End If Next End If End If End If Next Next 最後再用Textjoin把紀錄在7~52欄的遺漏紀錄整合在同一格內 然後為了方便辨識雜亂文章中的各個暗號 也去網路上找了幫特定字串上色的寫法 https://access-excel.tips/excel-vba-change-partial-text-color/ 我是用Macro 1 – Change partial text color using VBA Macro這個 目前的寫法雖然可以正常運作 但速度上還是有點慢,在有600條暗號的情況下,至少也要60秒才能檢查完 不知道是否有其他方式可以加快運算的速度? 而且現在還有個問題是如果暗號中有兩個9527 但解碼後只有一個唐伯虎,這種情況也不會被判斷成解碼缺失 所以在想是不是應該寫另一個用資料剖析功能運算的版本來測試看看..... 把每個暗號個別分開,就可以連同數量不一致的也抓出來 希望有人可以提供意見,感謝 --
QR Code



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 123.193.189.222 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Office/M.1570466433.A.3AB.html
1F:→ soyoso: 1.減少巢狀迴圈次數range.end().row來取得最後一筆有值的 10/08 07:27
2F:→ soyoso: 儲存格列號 10/08 07:27
3F:→ soyoso: 2.只針對出現暗號的儲存格,range.find或range.autofilter 10/08 07:27
4F:→ soyoso: 3.減少range.value的寫入,而是先寫入變數內,最後再一次 10/08 07:27
5F:→ soyoso: 性的寫入範圍內 10/08 07:27
6F:→ soyoso: 暗號有2個9527,只有1個唐伯虎方面(len(儲存格)-len( 10/08 07:27
7F:→ soyoso: replace(取代9527[變數])))/len(9527[變數]),或是ubound( 10/08 07:27
8F:→ soyoso: split()),這樣可得知字串內有出現多少次 10/08 07:27
9F:→ soyoso: 再判斷是否次數有相符 10/08 07:27
啊 忘了修文 迴圈上限的部分我後來有修正了 這樣就不用多檢查沒有值的欄位 range.find或range.autofilter我會再研究看看 另外 寫入變數內再拿出來的做法有範例嗎? 網站也可 然後雖然可能不會用到了,但還是想問一下 range.value=值 跟 range="值" 在運算速度上是有差的嗎? ※ 編輯: Kamikiri (60.248.94.55 臺灣), 10/08/2019 10:16:46
10F:→ soyoso: 寫入再拿出來,不確定所謂的拿出來是指?一次性寫入範圍內 10/08 09:56
11F:→ soyoso: 嗎?如果是的話寫入變數的話,變數(索引值,索引值[二維])= 10/08 09:58
12F:→ soyoso: 判斷內原本要寫入儲存格的值;最後迴圈都執行完畢,在 10/08 09:59
13F:→ soyoso: range(和變數維度、個數相同的範圍)=變數 的方式寫入 10/08 10:00
14F:→ soyoso: range.value 或 range=值方面測試寫入10次10萬資料上 10/08 10:06
15F:→ soyoso: 二者看來是差不多的 https://i.imgur.com/ShXYHag.jpg 10/08 10:06
感謝,剛剛在看到你的推文前上網查了一下 目前只想出以下寫法(還沒寫好寫正確 但應該類似)? Dim Array(1,52) as Variant if 解碼有誤 Array(Row2,Col) = "解碼遺漏:" & Decry 不知道創個Dictionary寫進去之後再整批拿出來是否也相同 總之目前大致上已經有方向,應該沒問題了,感謝解答 ※ 編輯: Kamikiri (60.248.94.55 臺灣), 10/08/2019 10:22:03
16F:→ soyoso: 如非一維的話,這要看dictionary是否可產生二維以上 10/08 10:22
17F:→ soyoso: 一維的話,一樣range= dictionary.keys的方式 10/08 10:23
18F:→ soyoso: dictionary.key寫入列的話,應需用工作表函數transpose轉 10/08 10:24
19F:→ soyoso: 置 10/08 10:24
了解,我晚點再GOOGLE研究看看 最後一問,如果你還有看到的話再麻煩解答 假如我想在解碼中使用萬用字元* 例如 95*7 讓9507~9597全部都視為應該被解碼為唐伯虎的話 是否只能使用Range.Find才有辦法? 發現其他寫法似乎都只會把*視為一般字元而非萬用字元 萬分感謝 ※ 編輯: Kamikiri (60.248.94.55 臺灣), 10/08/2019 11:33:39
20F:→ soyoso: like或range.autofilter 方面可用萬用字元 10/08 11:59
21F:推 foolkids: 一樣推薦Dictionary,30萬筆的比較時,效率還可以;超過 10/10 17:57
22F:→ foolkids: 的時候一樣有效能問題,要再多做些手段 10/10 17:57







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:iOS站內搜尋

TOP