返回列表 上一主題 發帖

[發問] 使用VBA將公式以文字型態於原位置顯示

[發問] 使用VBA將公式以文字型態於原位置顯示

使用VBA將公式以文字型態於原位置顯示

檔案內有範例及說明
使用VBA將公式以文字型態於原位置顯示.rar (4.28 KB)
{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

回復 1# ML089
  1. Sub TEST()
  2.   Dim ar()
  3.   Dim rngSrc As Range
  4.   
  5.   With Sheets(1)
  6.     Set rngSrc = .Range("A1:O6")
  7.    
  8.     ReDim ar(1 To rngSrc.Rows.Count, 1 To rngSrc.Columns.Count)
  9.     For i = 1 To UBound(ar)
  10.       For j = 1 To UBound(ar, 2)
  11.         If rngSrc.Cells(i, j).HasArray Then
  12.           ar(i, j) = "{" & rngSrc.Cells(i, j).FormulaArray & "}"
  13.         ElseIf rngSrc.Cells(i, j).HasFormula Then
  14.           ar(i, j) = "'" & rngSrc.Cells(i, j).Formula
  15.         Else
  16.           ar(i, j) = rngSrc.Cells(i, j).Value
  17.         End If
  18.       Next
  19.     Next
  20.    
  21.     rngSrc.Copy
  22.     With .[A9]
  23.       .PasteSpecial Paste:=xlPasteFormats '格式
  24.       .Resize(UBound(ar), UBound(ar, 2)).Value = ar
  25.     End With
  26.   End With
  27. End Sub
複製代碼

TOP

回復 1# ML089
  1. Sub ex()
  2. Dim A As Range
  3. For Each A In Cells.SpecialCells(xlCellTypeFormulas)
  4. If A.HasArray Then A = "{" & A.FormulaLocal & "}" Else A = "'" & A.FormulaLocal
  5. Next
  6. End Sub
複製代碼
學海無涯_不恥下問

TOP

回復 2# stillfish00

謝謝迅速回覆,學習到很多指令與技巧

希望繼續指導一下

延伸詢問 1
1. 公式文字是要寫回原儲存格位置
2. 要能選取某個工作簿(或某一個檔案)
3. 工作簿裡面包含不定數工作表,要將所有工作表裡有關公式全部改為文字型態(陣列公式前後加 {...} )
{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

TOP

回復 3# Hsieh

謝謝
Cells.SpecialCells(xlCellTypeFormulas) 這個可以只選到公式區,真強

下面幾個指令你與stillfish00下的方式不同,這有差別(或要注意的情況嗎)嗎?
.FormulaLocal
.FormulaArray
.Formula

麻煩再看3樓新的延伸問題,謝謝
{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

TOP

回復 3# Hsieh

我改寫抓全部工作表後,遇到沒有工作表內沒有公式時就會錯誤,要如何避免
  1. Sub ex00()
  2.     Dim A As Range
  3.     For Each sh In Sheets
  4.     For Each A In sh.Cells.SpecialCells(xlCellTypeFormulas)
  5.         If A.HasArray Then
  6.            A = "{" & A.FormulaLocal & "}"
  7.         Else
  8.            A = "'" & A.FormulaLocal
  9.         End If
  10.     Next
  11.     Next
  12. End Sub
複製代碼
{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

TOP

回復 3# Hsieh
回復 2# stillfish00

有新的問題
' 1. 當該工作表沒有公式時會產生錯誤
' 2. 遇到多格陣列公式時會跑很久也會錯誤
' 3. 單格陣列公式時前後用 {}包住, 多格陣列公式時前後用 []包住 - 表示

新的範例檔案
使用VBA將公式以文字型態於原位置顯示.rar (13.41 KB)
{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

TOP

回復 7# ML089
  1. Sub ex()
  2. Dim A As Range, C As Range, Sh As Worksheet
  3. fs = Application.GetOpenFilename("Excel Files (*.xls;*.xlsx;*.xlsm), *.xls;*.xlsx;*.xlsm") '開啟舊檔對話
  4. If fs <> False Then
  5. With Workbooks.Open(fs) '開啟舊檔
  6. Application.EnableEvents = False
  7. For Each Sh In .Sheets
  8. With Sh
  9. ar = .UsedRange
  10.    For i = 1 To UBound(ar, 1)
  11.       For j = 1 To UBound(ar, 2)
  12.          Set C = .UsedRange.Cells(i, j)
  13.          If C.HasArray Then
  14.             Mystr = "{" & C.Formula & "}"
  15.          ElseIf C.HasFormula Then
  16.             Mystr = "'" & C.Formula
  17.          Else
  18.             Mystr = C.Formula
  19.          End If
  20.          ar(i, j) = Mystr
  21.       Next
  22.    Next
  23. .UsedRange = ar
  24. End With
  25. Next
  26. Application.EnableEvents = True
  27. End With
  28. End If
  29. End Sub
複製代碼
學海無涯_不恥下問

TOP

回復 8# Hsieh

執行OK
只剩 多格陣列公式 要用 [ ] 括住,用來區別與單格陣列公式用 { }  括住

因為最後還要將這文字公式復原成公式。
最難的就是多格陣列公式的轉換(公式轉文字,文字再轉回公式),這部分我在網路上找很久都沒有查到可用的,
謝謝超版已經解決一半。
{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

TOP

回復 8# Hsieh

原來是文字 '=SUM(B2:M2) 會變成公式
我將 Mystr = C.C.Formula
改為 Mystr = C.Value

{...} 表示需要用 CTRL+SHIFT+ENTER 三鍵輸入公式

TOP

        靜思自在 : 閒人無樂趣,忙人無是非。
返回列表 上一主題