看板 ck50th310 關於我們 聯絡資訊
※ 引述《dom (gouf)》之銘言: 我不會vba 所以實際上我不知道怎麼作 但是以程式語言而言,精神都是相同的 我底下說的都是做法 : 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才能完成,有沒有比較簡單的寫法? 雖然沒用過vba,我只會錄巨集而已 這個功能用錄製巨集再修改的方式 應該是可以作到的 : 4.在vba裡面,要把一張工作表某範圍的內容,貼到另一張工作表去,有沒有比較快的 : 寫法?如果是要複製貼上固定的範圍,我知道可以用以下的語法達成: : 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當引數,那我該怎麼辦? 不知道cell是指什麼 就字面上來看應該是用來指定儲存格用 所以你用錯了 這應該是傳回該格之內容之類的 從語法來看 range內吃的是字串 所以依你的想法,應該是Range("x1:y5") //先說好實作上不可能這樣寫 x和y是字元變數 //這是想法 不過我會建議不要用x和y當變數名稱 因為excel儲存格也有X和Y列,容易混淆 //如Range("X1:Y5") 實作上因為已經在""內部了 所以"x1:y5"會被當成"X1:Y5來執行 //看函式定義啦,也可能error 你要自設一個字串變數s 將s=x1:y5 //不要這樣寫,是用vba的函式把字串重組 再作Range(s) //也許還要做字串型態的轉換 -- 神啊!讓我的手中發出萬丈光芒 消滅這世界上一切的邪惡! 必殺!CONKY FINGER! -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 140.112.94.125 ※ 編輯: conky 來自: 140.112.94.125 (07/04 11:44)