我有一个电子表格,一旦通过电子邮件发送,它的自动计算就会变成手动计算。我不使用保护表,因为如果数据源在邮件之后更新,公式仍然会更新。
在极少数情况下,可能需要再次邮寄该表,其中包含从其他表馈送的更改。那时我有代码可以复制工作表,然后复制并粘贴为值,使原始工作表保持粘性成为版本 II。
我试图避免在发送邮件时进行复制/粘贴值,因为如果没有必要,我想避免在工作簿中有两份工作表副本。
问题是,即使在复制工作表时自动更新已关闭,但在我能够复制和过去的值之前,它似乎已关闭。
有谁知道如何在将数据粘贴为值之前停止将数据输入工作表上的公式?
更新添加代码。
关闭自动计算的代码
Sub Turn_AutoUpdate_OFF()
' ***** STOPS alutomatic formular updating
' x - Defined Cell Names Lock_LABEL
' x - Image Lock_ON Lock_OFF
Application.ScreenUpdating = False ' do not see screen updating
If ActiveSheet.Name = "4_Transport" Then
' Make ON lock Small
ActiveSheet.Shapes.Range(Array("Lock_ONN")).Select ' x
Selection.ShapeRange.Height = 28.3464566929
' Make OFF lock Big
ActiveSheet.Shapes.Range(Array("Lock_OFF")).Select ' x
Selection.ShapeRange.Height = 46.7716535433
' Label
Range("TLock_LABEL").Select ' x
ActiveCell.FormulaR1C1 = "Auto Update is OFF"
Selection.HorizontalAlignment = xlLeft
With ActiveCell.Characters(Start:=15, Length:=4).Font
.FontStyle = "Fett"
.Size = 10
.Color = -16776961
End With
Range("B1").Select
' Turn automatic folular updating OFF
ActiveSheet.EnableCalculation = False
ElseIf ActiveSheet.Name = "5_Angebot" Then
' Make ON lock Small
ActiveSheet.Shapes.Range(Array("Lock_ONN")).Select ' x
Selection.ShapeRange.Height = 28.3464566929
' Make OFF lock Big
ActiveSheet.Shapes.Range(Array("Lock_OFF")).Select ' x
Selection.ShapeRange.Height = 46.7716535433
' Label
Range("ANLock_LABEL").Select ' x
ActiveCell.FormulaR1C1 = "Auto Update is OFF"
Selection.HorizontalAlignment = xlLeft
With ActiveCell.Characters(Start:=15, Length:=4).Font
.FontStyle = "Fett"
.Size = 10
.Color = -16776961
End With
Range("B1").Select
' Turn automatic folular updating OFF
ActiveSheet.EnableCalculation = False
Range("B1").Select
End If
Application.ScreenUpdating = True ' see screen updating
End Sub
然后复制以创建工作表 Angebot 的副本(工作机会的成本)
Sub New_Angebot_II()
' ***** Creates copy of sheet 5_Angebot *****
' x Defined Cell Names - ANVersion , ANReplaced
Dim fs As Worksheet
Dim es As Worksheet
Dim ns As Worksheet
Set fs = Sheets("5_Angebot") ' From WorkSheet
Set es = Sheets("4_Data Form") ' End on WorkSheet
' ns = Sheets("5_Angebot I") ' New WorkSheet - oooo
Application.ScreenUpdating = False ' do not see screen updating
' Check if the current Angebot is the first (I)
fs.Select
If Range("ANVersion").Value <> "I" Then ' x
MsgBox " Check if Angebot II has already been created " & vbNewLine & _
" Choose option to Create Angebot III", , "Check if Angebot II already exists"
es.Select
Exit Sub
End If
' Give User a opportunity to stop Copy
If MsgBox(" Angebot I will have its values fixed" & vbNewLine & _
" and be renamed as Anbebot II" & vbNewLine & vbNewLine & _
" Are you sure you want to create a New Angebot…?", vbQuestion + vbYesNo) <> vbYes Then
es.Select
Exit Sub
End If
' Select & Copy 5_Angebot
fs.Copy Before:=fs
' Change all formulars to fixed values
ActiveSheet.Select
Cells.Select
Selection.Copy
Selection.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks _
:=False, Transpose:=False
Application.CutCopyMode = False ' empties the clipboard and clears the memory cache
Range("B1").Select
' Rename sheet as old Angebot
ActiveSheet.Name = Replace$(ActiveSheet.Name, "(2)", "I")
Set ns = ActiveSheet ' New WorkSheet - oooo
Range("B1").Select
' Remove all the macro Buttons and shapes
'Dim i As Integer
If ActiveSheet.ProtectContents = True Then
MsgBox "The Current Workbook or the Worksheets which it contains are protected." & vbLf & _
" Please resolve these issues and try again."
End If
On Error Resume Next
ActiveSheet.Buttons.Delete
Dim Shp As Shape
For Each Shp In ActiveSheet.Shapes
Shp.Delete
Next Shp
' Protect sheet from updates
' Label
Range("A4").Select ' x
ActiveCell.FormulaR1C1 = "LOCK is ON"
Selection.HorizontalAlignment = xlRight
With ActiveCell.Characters(Start:=9, Length:=2).Font
.FontStyle = "Fett"
.Size = 10
.Color = -16776961
End With
Range("B1").Select
' PROTECT
ActiveSheet.Protect DrawingObjects:=True, Contents:=True, Scenarios:=True
' Go to 5_Angebot change Heading to II
fs.Select
Range("ANVersion").Select ' x
ActiveCell.FormulaR1C1 = "II"
Range("B1").Select
' Remove EMAILED Heading
Range("ANEmailed").Select ' x
ActiveCell.FormulaR1C1 = ""
Range("ANEmailDate").Select ' x
ActiveCell.FormulaR1C1 = ""
Range("B1").Select
' Turn Automatic update ON
Call Turn_AutoUpdate_ONN
' Go Back to 4_Data Form
es.Select
Range("B1").Select
Application.ScreenUpdating = True ' see screen updating
End Sub