找回密碼 或 安全提問
 註冊
|註冊|登錄

伊莉討論區

搜索
尊貴會員無限觀看附件圖片尊貴會員無限看帖不用回覆搞笑、娛樂、精彩的影片讓你看
國中無碼流出強姦出包王女mgvr高中
acrobat サキュバkevin大澤美加酒店genshin

休閒聊天興趣交流學術文化旅遊交流飲食交流家庭事務PC GAMETV GAME
熱門線上其他線上感情感性寵物交流家族門派動漫交流貼圖分享BL/GL
音樂世界影視娛樂女性頻道潮流資訊BT下載區GB下載區下載分享短片
電腦資訊數碼產品手機交流交易廣場網站事務長篇小說體育運動時事經濟
上班一族博彩娛樂

[繁]關於我轉生變成史

[繁]THE NEW GATE 04-

[繁]轉生貴族憑鑑定技

(4月新番)[繁]THE NEW

[繁]怪人的沙拉碗03-

[繁]老夫老妻重返青春
C & C++ 語言C# 語言Visual Basic 語言PHP 語言JAVA 語言
查看: 5343|回復: 5
打印上一主題下一主題

[求助]excel vba判斷顏色取值範圍設定問題[複製鏈接]

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
155
積分
1287 點
潛水值
47875 米
樓主
發表於 2017-2-8 06:12 AM|顯示全部樓層
回覆中加入附件並不會使你增加積分,請使用主題方式發佈附件。
本帖最後由 tryit244178 於 2017-2-8 10:22 AM 編輯

首先加入這2個副程式
  1. Private Sub CopyTransparentCell(ByVal seachRange As String)
  2.     Dim i As Range
  3.     Dim offestColumn As Integer
  4.     Const Transparent As Long = 16777215
  5.    
  6.     For Each i In Sheet1.Range(seachRange)
  7.         If i.Interior.Color = Transparent Then
  8.             offestColumn = i.column - 1
  9.             Sheet2.Cells(GetLastRow(offestColumn), offestColumn).value = Sheet1.Range("A" & i.Row).value
  10.         End If
  11.     Next i
  12. End Sub

  13. Private Function GetLastRow(ByVal column As Integer) As Integer
  14.     GetLastRow = Sheet2.Cells(Sheet2.Cells.Rows.Count, column).End(xlUp).Row + 1
  15. End Function
複製代碼

然後在按鈕裡加入這行
  1.     CopyTransparentCell "B2:C13"
複製代碼
...
瀏覽完整內容,請先 註冊登入會員

點評

tryit244178 有個變數名字打錯了,已修正  發表於 2017-2-8 09:40 AM

使用道具檢舉

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
155
積分
1287 點
潛水值
47875 米
頭香
發表於 2017-2-8 04:00 PM|顯示全部樓層
本帖最後由 tryit244178 於 2017-2-11 04:18 AM 編輯

那就把 If i.Interior.Color = Transparent Then 這行換成你的格式化條件

假如你的條件是儲存格內的值等於0,就改成
If Not i.Value = 0 Then

應該也能達到同樣的效果
記得把 Const Transparent As Long = 16777215 刪掉

點評

tryit244178 這邊改成比對數值  發表於 2017-2-11 06:04 AM
若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
155
積分
1287 點
潛水值
47875 米
3
發表於 2017-2-9 10:02 AM|顯示全部樓層
本帖最後由 tryit244178 於 2017-2-11 04:18 AM 編輯

再加入這個函式
  1. Private Function ComparisonData(ByVal value As String, ByVal comparisonRange As String) As Boolean
  2.     Dim i As Range
  3.    
  4.     ComparisonData = True
  5.    
  6.     For Each i In Sheet1.Range(comparisonRange)
  7.         If value = i.value Then
  8.             ComparisonData = False
  9.             Exit For
  10.         End If
  11.     Next i
  12. End Function
複製代碼

然後把 If i.Interior.Color = Transparent Then
換成 If ComparisonData(i.value, "K2:V23") Then

Const Transparent As Long = 16777215 記得刪掉

我發現你是把 CopyTransparentCell "C2:J26" 放在 ex() 裡面
其實可以不用ex(),而直接使用。因為這些程序並不是修改ex()用的
...
瀏覽完整內容,請先 註冊登入會員
成為伊莉的版主,你將獲得更高級和無限的權限。把你感興趣的版面一步步地發展和豐盛,那種滿足感等著你來嚐嚐喔。

使用道具檢舉

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
155
積分
1287 點
潛水值
47875 米
4
發表於 2017-2-10 03:30 AM|顯示全部樓層
本帖最後由 tryit244178 於 2017-2-11 04:18 AM 編輯

用這個試試
順便說明一下
offestColumn = i.column - 1
這個是你要貼到 工作表2 的位置
減 1 的話,就是貼到 A 欄;減 0 就是 B 欄;加 1 就是 C 欄…以此類推
...
瀏覽完整內容,請先 註冊登入會員

使用道具檢舉

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
155
積分
1287 點
潛水值
47875 米
5
發表於 2017-2-10 06:10 PM|顯示全部樓層
如果瀏覽伊莉時速度太慢或無法連接,可以使用其他分流瀏覽伊莉,www01.eyny.com(02,03)。
本帖最後由 tryit244178 於 2017-2-11 04:19 AM 編輯

最新的程序其實做得就是你說的那些事。(一開始是判斷顏色就是)

從你的描述來看,代表比對出來結果,全被判斷為不同
你貼出來的圖裡,比對區放的值都是數字
登錄區裡放的也是數字嗎?
還是有什麼特殊條件,才會造成放到比對區裡的數字?

還有,你登錄區的資料是放在哪個工作表?
...
瀏覽完整內容,請先 註冊登入會員





若有安裝色情守門員,可用無界、自由門等軟件瀏覽伊莉。或使用以下網址瀏覽伊莉: http://www.eyny.com:81/index.php

使用道具檢舉

Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6Rank: 6

帖子
155
積分
1287 點
潛水值
47875 米
6
發表於 2017-2-11 04:09 AM|顯示全部樓層
所有積分大於負-100的壞孩子,將可獲得重新機會成為懲罰生,權限跟幼兒生一樣。
本帖最後由 tryit244178 於 2017-2-11 06:36 AM 編輯

因為一次清除了很多儲存格
但轉大寫的函式,一次只能轉一個儲存格,所以會產生錯誤
把最上面的程序改為
  1. Private Sub Worksheet_Change(ByVal Target As Range)
  2.     Dim i As Range
  3.    
  4.     Application.EnableEvents = False
  5.     For Each i In Target
  6.         If Not i = "" Then
  7.             i = UCase(i)
  8.         End If
  9.     Next i
  10.     Application.EnableEvents = True
  11. End Sub
複製代碼


UCase() 是小寫轉大寫的函式
下載: 訪客無法瀏覽下載點,請先 註冊登入會員



最後這段程序…看起來似乎是點到第24行的時候會跳到下一欄的第2行
大概是懶得換行吧XD
  1. Private Sub Worksheet_SelectionChange(ByVal Target As Range)
  2.     If Target.Row = 24 Then Cells(2, Target.column + 1).Select  '懶得換行
  3. End Sub
複製代碼

你可以像這樣為程序註解,『'』(冒號右邊那顆鍵)
...
瀏覽完整內容,請先 註冊登入會員

使用道具檢舉

您需要登錄後才可以回帖 登錄 | 註冊

Powered by Discuz!

© Comsenz Inc.

重要聲明:本討論區是以即時上載留言的方式運作,對所有留言的真實性、完整性及立場等,不負任何法律責任。而一切留言之言論只代表留言者個人意見,並非本網站之立場,用戶不應信賴內容,並應自行判斷內容之真實性。於有關情形下,用戶應尋求專業意見(如涉及醫療、法律或投資等問題)。 由於本討論區受到「即時上載留言」運作方式所規限,故不能完全監察所有留言,若讀者發現有留言出現問題,請聯絡我們。有權刪除任何留言及拒絕任何人士上載留言,同時亦有不刪除留言的權利。切勿上傳和撰寫 侵犯版權(未經授權)、粗言穢語、誹謗、渲染色情暴力或人身攻擊的言論,敬請自律。本網站保留一切法律權利。
回頂部