Re: [VBA ] excel與VBA的問題求救
※ 引述《dom (gouf)》之銘言:
: 1.我希望把某工作表的名稱設為某儲存格的數值,該儲存格的資料型式是日期資料,
: 如2000年1月1日。語法大致如下:
: y = CStr(Worksheets(1).Cells(1, 3).Value)
: Worksheets(3).Name = y
: 我知道excel的工作表名稱內不能含"/"符號,所以日期儲存的格式特別用"2000年
: 1月1日"而非"2000/01/01",但是vba在執行時似乎還是將日期資料視作"2000/01/01"
: 的格式,因此說我語法錯誤。那我要怎麼樣才能把工作表名稱命名為某天的日期?
: (手動key in除外)
: 2.要怎麼樣才能讓vba在執行到一半時先將目前的活頁簿存檔?因為程式可能要跑
: 很久,外一中途當機,沒中途存檔的話豈不欲哭無淚?
: 3.我有一些股票交易資料的格式如下:
: 日期 代號
: 2000/01/01 1000
: 2000/01/01 1001
: 2000/01/01 3002
: 2000/01/02 1000
: 2000/01/02 2303
: 2000/01/03 1000
: 2000/01/03 2323
: 2000/01/04 2035
: .
: .
: .
: 我希望自動把每一天的資料放到不同工作表,例如2000/01/01的交易資料放到工作表
: "2000年1月1日"、2000/01/02的交易資料放到工作表"2000年1月2日",以此類推。
: 有沒有不用寫vba,靠excel內建的功能就可完成的方法?(可能有人會說把資料用日期
: 篩選後再一天一天貼上,問題是我的資料有很很多年,每年有兩百多天,一天一天貼
: 會貼到死)。如果要靠vba才能完成,有沒有比較簡單的寫法?
: 4.在vba裡面,要把一張工作表某範圍的內容,貼到另一張工作表去,有沒有比較快的
: 寫法?(我知道可以用array加上for loop來達成,可是我想問有沒有copy、past之類的
: 指令?)
: 謝謝大大把我的問題看完,能解決小弟的疑惑的話就更感激囉。
第4點我補充一下,如果是要複製貼上固定的範圍,我知道可以用以下的語法達成:
Worksheets("Sheet1").Range("A1:D4").Copy _
destination:=Worksheets("Sheet2").Range("E5")
但是我要複製的範圍是不固定的,例如說我要複製的是第x列第一格到第y列第5行的
範圍,其中x,y均為變數,用vba的語法的話大概像這樣:
Worksheets(1).Range("Cells(x,1):Cells(y,5)").Copy _
Destination:=Worksheets(2).Range("E5")
不過上面的語法無法執行,似乎是因為range裡面不能以cells當引數,那我該怎麼辦?
--
※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 203.203.39.78
討論串 (同標題文章)
本文引述了以下文章的的內容:
完整討論串 (本文為第 2 之 2 篇):
Visual_Basic 近期熱門文章
PTT數位生活區 即時熱門文章