註冊
登錄
首頁
論壇版規
禁止列表
說明
地圖
數位書香
私人消息 (0)
公共消息 (0)
論壇任務 (0)
系統消息 (0)
好友消息 (0)
帖子消息 (0)
麻辣家族討論版版
»
Excel程式區
» 執行速度過慢 如何簡化
返回列表
下一主題
上一主題
發帖
[發問]
執行速度過慢 如何簡化
stillfish00
發短消息
加為好友
stillfish00
當前離線
UID
9276
帖子
1018
主題
15
精華
0
積分
1058
金錢
1058
點名
0
作業系統
win7 32bit
軟體版本
Office 2016 64-bit
閱讀權限
50
性別
男
來自
桃園
在線時間
1141 小時
註冊時間
2012-5-9
最後登錄
2022-9-28
大學生
帖子
1018
主題
15
精華
0
積分
1058
點名
0
作業系統
win7 32bit
軟體版本
Office 2016 64-bit
閱讀權限
50
性別
男
來自
桃園
註冊時間
2012-5-9
最後登錄
2022-9-28
1
#
跳轉到
»
發表於 2015-4-15 20:06
|
顯示全部帖子
本帖最後由 stillfish00 於 2015-4-15 20:16 編輯
回復
7#
lyc43210
Delete/Copy 這些動作都比較慢 , 資料量大時盡量少用
'假設每行最少都有一筆資料
Sub Test()
Dim arSrc, arDes, m As Long, n As Long
With ActiveSheet
arSrc = .[a1].CurrentRegion.Value
If UBound(arSrc) Mod 2 = 1 Then MsgBox "資料非偶數行": Exit Sub
ReDim arDes(1 To UBound(arSrc) / 2, 1 To UBound(arSrc, 2))
n = 1: m = 1
For i = 1 To UBound(arSrc)
For j = 1 To UBound(arSrc, 2)
If arSrc(i, j) = "" Then
Exit For
Else
If n > UBound(arDes, 2) Then ReDim Preserve arDes(1 To UBound(arDes), 1 To n)
arDes(m, n) = arSrc(i, j)
n = n + 1
End If
Next
If i Mod 2 = 0 Then n = 1 : m = m + 1
Next
End With
'處理完後的資料新增工作表貼上
With Sheets.Add
.[a1].Resize(UBound(arDes), UBound(arDes, 2)).Value = arDes
End With
End Sub
複製代碼
表達不清、題意不明確、沒附檔案格式、沒有討論問題的態度~~~~~~以上愛莫能助。
TOP
靜思自在 :
一個缺口的杯子,如果換一個角度看它,它仍然是圓的。
返回列表
下一主題
上一主題
EXCEL專屬討論區
Excelㄧ般區
Excel程式區
進階應用專區
OFFICE 系列
Word
PowerPoint
Access
Office不分區
程式語言
VB 與 VB.Net
C 與 C#
Java 與 J#
程式設計不分區
資料庫
ORACLE
My SQL
MS SQL
網頁設計
ASP 與 ASP.NET
PHP
PHP+MySQL 入門實作
JavaScript
FLASH / ActionScript
HTM/ HTML/ CSS
網頁設計不分區
電腦與作業系統
電腦各種硬體討論
一般電腦軟體討論
論壇事務
管理公告
投訴反映
新手測試
愛 ‧ 生活
公益佈告欄
生活與感動
[收藏此主題]
[關注此主題的新回復]
[通過 QQ、MSN 分享給朋友]
申請友情鏈接
Facebook粉絲