返回列表 上一主題 發帖

[發問] 如何複製表格到別的工作表

[發問] 如何複製表格到別的工作表

本帖最後由 brabus 於 2011-12-3 21:48 編輯

如附件活頁簿1中所示
我想在按下同步按鈕後
把活頁簿1儲存格中b1到d87的資料
複製到活頁簿2中的"資料確認"那張工作表的b1到d87儲存格(未來如果資料增加的話,要可以全部複製,不過只會用到b到d的3個欄位)
現在活頁簿2中的"資料確認"工作表被"隱藏"vba密碼是twbts
先不考慮活頁簿1中的資料的內容,因為到時會key入正確資料
要考量的是這2個檔可能放在任一磁碟中
不限是在桌面或是"我的文件"中,可能在d槽或e槽......
未來也可能要同時存到活頁簿3中的b到d欄....
請高指導一下要怎麼寫vba

活頁簿2.rar (5.53 KB)

活頁簿1.rar (11.07 KB)

jeason

  1. Private Sub CommandButton1_Click()
  2. fs = Application.GetOpenFilename("Excel Files (*.xls), *.xls") '開啟目的檔案
  3. With Workbooks.Open(fs)
  4.   Columns("B:D").Copy .Sheets("資料確認").[B1] '複製資料
  5. End With

  6. End Sub
複製代碼
回復 1# brabus
學海無涯_不恥下問

TOP

回復 2# Hsieh

請問一下Hsieh大大
你所說的"fs = Application.GetOpenFilename("Excel Files (*.xls), *.xls") '開啟目的檔案"
上面這段是不是指的是取得現行檔案的路徑嗎?
那2個(*.xls)是什麼意思????一個是現在的試算檔名另一個是第二個試算嗎?
另外  .Sheets("資料確認").[B1]指的是copy到"b1"試算表的資料確認表格嗎???   
謝謝你哦
jeason

TOP

本帖最後由 Hsieh 於 2011-12-1 14:55 編輯

回復 3# brabus


    fs = Application.GetOpenFilename("Excel Files (*.xls), *.xls")
這是開啟舊檔的對話方塊,可供使用者選擇要貼上資料的檔案
.Sheets("資料確認").[B1]
就是被開啟的檔案中資料確認工作表的B1儲存格,也就是被貼上資料的位置
至於2個*.xls請參閱GetOpenFilename的FileFilter 引數說明
FileFilter     選擇性的 Variant。是指定檔案篩選規則的字串。
此字串由一檔案篩選字串與 MS-DOS 萬用字元表達的檔案篩選規則描述組成,中間以逗點分隔。[檔案類型] 下拉式清單方塊中會列出各組字串。例如,下列字串指定兩個檔案篩選,文字和增益集:文字檔 (*.txt),*.txt,增益集檔案 (*.xla),*.xla。
若要使用多個 MS-DOS 萬用字元運算式組成單一檔案篩選類型,各萬用字元之間需以分號分隔;例如,"Visual Basic Files (*.bas; *.txt),*.bas;*.txt"。
如果省略,則此引數將預設為 "All Files (*.*),*.*"。
學海無涯_不恥下問

TOP

回復 4# Hsieh
有上網找到了GetOpenFilename的用法
感謝Hsieh的指教
我另外作了修正
要把h21的到j60的儲存格copy到資料夾的同一個位置
分享給大家
   Range("h21:j60").Copy .Sheets("資料確認").[h21]
jeason

TOP

回復 4# Hsieh


    請教一下Hsieh大
我想到一個問題,那就是人名似乎不應顥示出來
所以想把按鈕搬到空白的工作表2,想說這樣就不會讓人生看到名單而可以在背景作業
所以把式子改成
Private Sub CommandButton1_Click()
fs = Application.GetOpenFilename("Excel Files (*.xls), *.xls") '開啟目的檔案
With Workbooks.Open(fs)
  Sheets("sheet1").Columns("B:F").Copy .Sheets("資料確認").[B1] '複製資料
  Sheets("sheet1").Range("J16:K300").Copy .Sheets("資料確認").[J16]
End With
End Sub
執行後結果出現"陣列索引超出範圍",請問我該怎麼修正呢
jeason

TOP

回復 6# brabus
把按鈕搬到空白工作表2
那這個空白工作表2是否與要複製的來源工作表在同一個檔案呢?
就是Sheets("sheet1")是否存在?
學海無涯_不恥下問

TOP

回復 7# Hsieh


    你好我己經修正附件活頁簿1了
我上次問的是在活頁簿1的工作表1設按鈕
把資料copy到活頁簿2這個檔案上的"資料確認"工作表中
現在想把工作表1這個按鈕移到同活頁簿的工作表2上
因為不想讓人看到工作表1上的人名資料
想在工作表2上按按鈕,就可以完成上面原來所說的複制的工作
謝謝你
jeason

TOP

回復 8# brabus
"陣列索引超出範圍"
的原因應該是因為工作表不存在
你檢查檔案看看你的工作表名稱是否正確
學海無涯_不恥下問

TOP

回復 9# Hsieh

檔案存在啊,
我試著調整了一陣子
,現在執行後出現With Workbooks.Open語法錯誤
我把新檔上傳了
請您幫我看該怎麼調整修正
謝謝

活頁簿1.rar (11.78 KB)

活頁簿2.rar (3.57 KB)

jeason

TOP

        靜思自在 : 脾氣嘴巴不好,心地再好也不能算是好人。
返回列表 上一主題