Board logo

標題: [發問] 關於自動開啟指定位置檔案or超連結路徑的檔案 [打印本頁]

作者: starry1314    時間: 2015-6-3 15:47     標題: 關於自動開啟指定位置檔案or超連結路徑的檔案

本帖最後由 starry1314 於 2015-6-3 15:49 編輯

如何加入以下指令呢? 因我加進Dim wsTarget As Worksheet
底下 好像會造成按鈕行不對 所以沒辦法判斷~
或是要怎麼設定成指定路徑然後檔名,可以讀取儲存格的檔名做變數呢?

去數據表格 點選B22的超連結 開啟客戶明細
  Sheets("數據").Select
    Range("B22").Select
    Selection.Hyperlinks(1).Follow NewWindow:=False, AddHistory:=True
  1. Sub 貼上資料至_客服管理_自動判斷()
  2. '
  3. ' 貼上資料至_客服管理 巨集
  4.     Dim lSourceRow As Long, lTargetRow As Long
  5.     Dim wsTarget As Worksheet
  6.     With ActiveSheet
  7.         lSourceRow = .Buttons(Application.Caller).TopLeftCell.Row   '被點擊的該按鈕行數
  8.         If .Cells(lSourceRow, "C").Text = vbNullString Then MsgBox "日期欄無資料,無法判斷貼上月份": Exit Sub
  9.         Set wsTarget = Workbooks("客戶明細-業務專用.xlsm").Sheets(GetMonthStr(.Cells(lSourceRow, "C"))) '日期判斷要貼上的工作表
  10.         lTargetRow = wsTarget.Cells(Rows.Count, "B").End(xlUp).Row + 1  '要貼上的位置
  11.         Application.ScreenUpdating = False
  12.         .Range(.Cells(lSourceRow, "A"), .Cells(lSourceRow, "P")).Copy '複製A欄到P欄的資料
  13.         wsTarget.Cells(lTargetRow, "B").PasteSpecial Paste:=xlPasteValues '在B欄開始貼上
  14.         wsTarget.Paste Link:=True '貼上連結
  15.         Application.ScreenUpdating = True '貼上連結
  16.     End With
  17.    
  18.     With wsTarget
  19.         .Hyperlinks.Add Anchor:=.Cells(lTargetRow, "A"), _
  20.                         Address:=ThisWorkbook.FullName, _
  21.                         SubAddress:=ThisWorkbook.ActiveSheet.Name & "!" & Rows(lSourceRow).Address, _
  22.                      TextToDisplay:=.Cells(lTargetRow, "a").Text

  23.     End With
  24. End Sub
複製代碼

作者: luhpro    時間: 2015-6-4 00:12

如何加入以下指令呢? 因我加進Dim wsTarget As Worksheet
底下 好像會造成按鈕行不對 所以沒辦法判斷~
或 ...
starry1314 發表於 2015-6-3 15:47
  1. Dim wsTarget As Worksheet
  2. '===== 加底下這些指令=====
  3. Dim sPath$

  4. sPath = ThisWorkbook.Path
  5. ChDrive sPath
  6. ChDir sPath
  7. '===== 加上面這些指令=====
  8.     With ActiveSheet
複製代碼

作者: starry1314    時間: 2015-6-4 15:47

已加入 但會跳出 執行程需或呼叫錯誤
[attach]21101[/attach]
  1. Sub 貼上資料至_客服管理_自動判斷()
  2. '
  3. ' 貼上資料至_客服管理 巨集
  4.     Dim lSourceRow As Long, lTargetRow As Long
  5.     Dim wsTarget As Worksheet
  6.     Dim sPath$

  7. sPath = ThisWorkbook.Path
  8. ChDrive sPath
  9. ChDir sPath
  10.     With ActiveSheet
  11.         lSourceRow = .Buttons(Application.Caller).TopLeftCell.Row   '被點擊的該按鈕行數
  12.         If .Cells(lSourceRow, "C").Text = vbNullString Then MsgBox "日期欄無資料,無法判斷貼上月份": Exit Sub
  13.         Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(GetMonthStr(.Cells(lSourceRow, "C"))) '日期判斷要貼上的工作表
  14.         lTargetRow = wsTarget.Cells(Rows.Count, "B").End(xlUp).Row + 1  '要貼上的位置
  15.         Application.ScreenUpdating = False
  16.         .Range(.Cells(lSourceRow, "A"), .Cells(lSourceRow, "AF")).Copy '複製A欄到P欄的資料
  17.         wsTarget.Cells(lTargetRow, "B").PasteSpecial Paste:=xlPasteValues '在B欄開始貼上
  18.        wsTarget.Paste Link:=True '貼上連結
  19.         Application.ScreenUpdating = True '貼上連結
  20.     End With
  21.    
  22.     With wsTarget
  23.         .Hyperlinks.Add Anchor:=.Cells(lTargetRow, "A"), _
  24.                         Address:=ThisWorkbook.FullName, _
  25.                         SubAddress:=ThisWorkbook.ActiveSheet.Name & "!" & Rows(lSourceRow).Address, _
  26.                      TextToDisplay:=.Cells(lTargetRow, "a").Text

  27.     End With
  28. End Sub
複製代碼
回復 2# luhpro
作者: luhpro    時間: 2015-6-5 23:25

已加入 但會跳出 執行程需或呼叫錯誤
回復  luhpro
starry1314 發表於 2015-6-4 15:47

我提供的指令若發生錯誤,
原因大部分應該都是 "找不到路徑" 才對.

你的程式乍看之下看不出來錯誤在哪裡,
你試試按下 "偵錯" 按鈕,
看看是哪一行發生此錯誤.
作者: starry1314    時間: 2015-6-5 23:48

回復 4# luhpro

這一段,麻煩看看囉~
lSourceRow = .Buttons(Application.Caller).TopLeftCell.Row   '被點擊的該按鈕行數
[attach]21111[/attach]
作者: luhpro    時間: 2015-6-6 00:15

回復  luhpro

這一段,麻煩看看囉~
lSourceRow = .Buttons(Application.Caller).TopLeftCell.Row   '被 ...
starry1314 發表於 2015-6-5 23:48

指令對象與呼叫方式都不正確喔 :
Caller 屬性
傳回關於呼叫 Visual Basic 的資訊 (詳細內容請參閱 [備註] 部份)。

expression.Caller(Index)
expression    必選。此運算式會傳回 Application 物件。

Index    選擇性的 Variant。陣列的索引。僅當本屬性傳回陣列時此引數才有用 (詳細內容請參閱 [備註] 部份)。

備註
本屬性將傳回關於呼叫 Visual Basic 的資訊,如下表所示。

呼叫者                                                                                                                 傳回值
在單一儲存格中輸入的自訂函數                                                                     代表該儲存格的 Range 物件
在儲存格範圍中作為陣列公式一部份的自訂函數                                         代表該儲存格範圍的 Range 物件
Auto_Open、Auto_Close、Auto_Activate 或 Auto_Deactivate 巨集  以文字模式傳回的文件名稱
由OnDoubleClick 或 OnEntry 屬性所設定的巨集                                      該巨集所套用的圖表物件辨識符號或儲存格參照 (若適用) 的名稱
[工具] 功能表中的 [巨集] 對話方塊,或上述之外的其他呼叫者                #REF! 錯誤值
作者: starry1314    時間: 2015-6-6 00:27

回復 6# luhpro


    這邊真的看不懂...因為原本程式是正常運作的
只是按鈕必須放在要複製的資料 同一行 才有辦法複製,
但現在是在另外一個頁面做按鈕呼叫此巨集但就沒辦法執行了.有先讓巨集1去先點要複製資料的那一行 再呼叫此自動複製資料的巨集 但還是無法完成
作者: luhpro    時間: 2015-6-6 00:30

本帖最後由 luhpro 於 2015-6-6 00:36 編輯
回復  luhpro
    這邊真的看不懂...因為原本程式是正常運作的
只是按鈕必須放在要複製的資料 同一行 ...
starry1314 發表於 2015-6-6 00:27

你不用這樣設計啊.

如果要區分的是按鈕:
只要設定一個全域變數,
接著在每一個按鈕的 Click 處理程序區塊內各別設定此變數不同的值,
就可以區分了.

如果要區分的是被選取的儲存格:
Selection(1).Address 可取得 $A$2 形式的儲存格位址
Selection(1).Row 取得其列號
Selection(1).Column 取得其欄號
用 (1) 是只取左上角那一個儲存格,
避開多選時儲存格目標太多的情形.
作者: starry1314    時間: 2015-6-6 01:09

回復 8# luhpro
目前改至以下模式
但在        wsTarget.Cells(lSourceRow, "B").PasteSpecial Paste:=xlPasteValues '在B欄開始貼上 會出錯 找不出該怎麼修改
  1. Sub 貼上資料至_客服管理_自動判斷()
  2. '
  3. ' 貼上資料至_客服管理 巨集
  4.     Dim lSourceRow As Long, lTargetRow As Long
  5.     Dim wsTarget As Worksheet
  6.     Dim sPath$

  7.     sPath = ThisWorkbook.Path
  8.     ChDrive sPath
  9.     ChDir sPath
  10.     With ActiveSheet
  11.      lSourceRow = Selection(1).Row + 2 '被點擊的該按鈕行數
  12.      Windows("客戶明細-客服專用.xlsm").Activate
  13.      Sheets("一月").Select
  14.      endRow = ActiveSheet.UsedRange.Cells(Rows.Count, "B").End(xlUp).Row + 1
  15.         Application.ScreenUpdating = False
  16.         .Range(.Cells(endRow, "A"), .Cells(endRow, "AF")).Copy '複製A欄到P欄的資料
  17.         wsTarget.Cells(lSourceRow, "B").PasteSpecial Paste:=xlPasteValues '在B欄開始貼上
  18.        wsTarget.Paste Link:=True '貼上連結
  19.         Application.ScreenUpdating = True '貼上連結
  20.     End With
  21.    
  22.     With wsTarget
  23.         .Hyperlinks.Add Anchor:=.Cells(lTargetRow, "A"), _
  24.                         Address:=ThisWorkbook.FullName, _
  25.                         SubAddress:=ThisWorkbook.ActiveSheet.Name & "!" & Rows(lSourceRow).Address, _
  26.                      TextToDisplay:=.Cells(lTargetRow, "a").Text

  27.     End With
  28. End Sub
複製代碼

作者: starry1314    時間: 2015-6-6 01:25

本帖最後由 starry1314 於 2015-6-6 01:36 編輯

回復 8# luhpro
真是太感謝幫忙了~解決掉我好幾個困擾的問題
已正常運作 ,但紅字部分有點冗長,可幫忙做優化嗎?
因沒加Windows("客戶明細-客服專用.xlsm").Activate
        Sheets("一月").Select
會在原本頁面做貼上資料的動作

另想請問一開始給我的
   sPath = ThisWorkbook.Path
ChDrive sPath
ChDir sPath
作用是? 因用監看式看不懂,嘗試把他拿掉還是正常運作

Sub 貼上資料()
'

    Dim lSourceRow As Long, lTargetRow As Long
    Dim wsTarget As Worksheet
    With ActiveSheet
        lSourceRow = Selection(1).Row  '被點擊的該按鈕行數
       ' If .Cells(lSourceRow, "C").Text = vbNullString Then MsgBox "日期欄無資料,無法判斷貼上月份": Exit Sub
        'Set wsTarget = Workbooks("客戶明細-業務專用.xlsm").Sheets(GetMonthStr(.Cells(lSourceRow, "C"))) '日期判斷要貼上的工作表
        Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(.cells("一月")
        Windows("客戶明細-客服專用.xlsm").Activate
        Sheets("一月").Select

        lTargetRow = wsTarget.Cells(Rows.Count, "B").End(xlUp).Row + 1 '要貼上的位置
        Application.ScreenUpdating = False
        .Range(.Cells(lSourceRow, "A"), .Cells(lSourceRow, "AF")).Copy '複製A欄到P欄的資料
        wsTarget.Cells(lTargetRow, "B").PasteSpecial Paste:=xlPasteValues '在B欄開始貼上
        wsTarget.Paste Link:=True '貼上連結
        Application.ScreenUpdating = True '貼上連結
    End With
   
    With wsTarget
        .Hyperlinks.Add Anchor:=.Cells(lTargetRow, "A"), _
                        Address:=ThisWorkbook.FullName, _
                        SubAddress:=ThisWorkbook.ActiveSheet.Name & "!" & Rows(lSourceRow).Address, _
                     TextToDisplay:=.Cells(lTargetRow, "a").Text

    End With
End Sub
作者: starry1314    時間: 2015-6-6 17:38

回復 8# luhpro


    回復 8# luhpro

請問關於
  1.          'lSourceRow = Selection(1).Row   '被點擊的該按鈕行數
  2.          lSourceRow = .Buttons(Application.Caller).TopLeftCell.Row
複製代碼
這是用按鈕做,那如果是使用圖案呢?
無法取得.Buttons屬性
作者: lpk187    時間: 2015-6-6 17:55

回復 10# starry1314


    除了 Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(.cells("一月") 這列
其他的若拿掉可以正常工作拿掉也無彷!
.Activate是指定作用中的工作簿、工作表,也就是說你現在在這裡工作。在程序中除非你指定後有特別作用,否則沒有什麼意義!
.Select是指定去選擇哪一個工作表或儲存格,然後在這工作。在程序中除非你指定後有特別作用,否則沒有什麼意義!
作者: luhpro    時間: 2015-6-7 09:24

本帖最後由 luhpro 於 2015-6-7 09:28 編輯
回復  luhpro
...
另想請問一開始給我的
   sPath = ThisWorkbook.Path
ChDrive sPath
ChDir sPath
作用是? 因用監看式看不懂,嘗試把他拿掉還是正常運作
...
starry1314 發表於 2015-6-6 01:25

這是對你 1# 所提 :
要怎麼設定成指定路徑然後檔名,可以讀取儲存格的檔名做變數呢?
猜測你是要先設定好目前工作目錄,
把所有會用到的檔案都放在該目錄下,
就不用在開啟檔案時還要另外指定檔案所在的目錄,
只要給檔名就可以使用該檔案了.

另外,這一行應該是不對的啊:
Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(.cells("一月")
Cells() 的括弧中間只能是 列號,行號 而不能是字串,
且你該行的括號也沒有成對.

Paste 函數執行時應該可以不用先把標的工作簿Activate,
也不用把標的工作表及標的儲存格 Select,
直接以 With wsTarget 與 End With包住,
再於其中用 . 代換即可.
或是用 wsTarget.cells... 亦可.

因為不能確認你語法有錯誤的這一行 :
Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(.cells("一月")
標的是否為可變動的,
所以暫時不能對那些指令做優化.


回復  luhpro
    回復  luhpro
請問關於這是用按鈕做,那如果是使用圖案呢?
無法取得.Buttons屬 ...
starry1314 發表於 2015-6-6 17:38

針對圖案?
這個我也不會喔,抱歉.
作者: starry1314    時間: 2015-6-7 10:24

回復 13# luhpro


    謝謝指導~我再研究一下,
作者: starry1314    時間: 2015-6-7 11:09

回復 13# luhpro


    另外,這一行應該是不對的啊:
Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(.cells("一月")
Cells() 的括弧中間只能是 列號,行號 而不能是字串,
且你該行的括號也沒有成對.

會不會是 因前面是有用日期判斷要使用哪個月份sheets 所已cells才可用
  1. Function GetMonthStr(inDate As Date) As String
  2.     Select Case Month(inDate)
  3.         Case 1
  4.             GetMonthStr = "一月"
  5.         Case 2
  6.             GetMonthStr = "二月"
  7.         Case 3
  8.             GetMonthStr = "三月"
  9.         Case 4
  10.             GetMonthStr = "四月"
  11.         Case 5
  12.             GetMonthStr = "五月"
  13.         Case 6
  14.             GetMonthStr = "六月"
  15.         Case 7
  16.             GetMonthStr = "七月"
  17.         Case 8
  18.             GetMonthStr = "八月"
  19.         Case 9
  20.             GetMonthStr = "九月"
  21.         Case 10
  22.             GetMonthStr = "十月"
  23.         Case 11
  24.             GetMonthStr = "十一月"
  25.         Case 12
  26.             GetMonthStr = "十二月"
  27.     End Select
  28. End Function
複製代碼

作者: luhpro    時間: 2015-6-8 21:54

本帖最後由 luhpro 於 2015-6-8 22:08 編輯
回復  luhpro
    另外,這一行應該是不對的啊:
Set wsTarget = Workbooks("客戶明細-客服專用.xlsm" ...
starry1314 發表於 2015-6-7 11:09

還是不對的啊.

首先,
你該行的括號也沒有成對,
這就已經先會發生語法錯誤而導致整個 Sub 應該都執行不下去了.

若要引用你 15# 所述的 Function,
那麼該行大約應該長成底下這樣 :
Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(GetMonthStr(inDate))
而不應該有 Cells 這個東東.

更遑論你那個 ("一月") 是已經釘死為 "一月" 的,
與 GetMonthStr 這個 Function 怎麼也不該牽在一起.

我剛剛再次查了一下 Excel 2003 中關於 Range 的說明, 確認它的敘述 :
Cells 屬性
可用 Cells(row, column) 傳回單個儲存格,其中 row 為列索引,column 為欄索引。

難道更新版的 Excel 中,
Cells 有其它新的語法嗎?
作者: starry1314    時間: 2015-6-8 22:57

回復 16# luhpro


    這就不了解了...因我當初貼的那段是可正常運作~
後來將表格統一在一個,就沒有使用這段指令了 ,
改使用像你講的
若要引用你 15# 所述的 Function,
那麼該行大約應該長成底下這樣 :
Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets(GetMonthStr(inDate))
使用為
Set wsTarget = Workbooks("客戶明細-客服專用.xlsm").Sheets("客戶明細")
另想請問inDate是?
作者: luhpro    時間: 2015-6-9 01:11

本帖最後由 luhpro 於 2015-6-9 01:13 編輯
回復  luhpro
    這就不了解了...因我當初貼的那段是可正常運作~
後來將表格統一在一個,就沒有使用 ...
starry1314 發表於 2015-6-8 22:57

那要看原檔案內容才能知道了.


另想請問inDate是?
starry1314 發表於 2015-6-8 22:57

請看 15 #
Function GetMonthStr(inDate As Date) As String
因為不能得知你呼叫 Function 時用的是什麼變數名稱,
自然直接套用 Function 上的變數名來說明.




歡迎光臨 麻辣家族討論版版 (http://forum.twbts.com/)