[英]Can I export only a range within a sheet using VBA?
我刚开始学习VBA并构建了一个导出特定工作表的小应用程序。 我想更进一步,只从该表中导出一个范围。
我尝试了各种不同的编码方案,但无济于事。
Sub saveSheetToCSV()
Dim myCSVFileName As String
Dim tempWB As Workbook
myCSVFileName = ThisWorkbook.Path & "\" & "EXPORT_" & VBA.Format(VBA.Now, "ddMMyyyy") & ".csv"
ThisWorkbook.Sheets("Data").Activate
ActiveSheet.Copy
Set tempWB = ActiveWorkbook
With tempWB
.SaveAs FileName:=myCSVFileName, FileFormat:=xlCSV, CreateBackup:=False
.Close
End With
End Sub
任何人都可以确认我会用什么代码来导出工作表中的范围? 我试图在名为“数据”的工作表中导出范围A2:D24,而不是像上面的当前代码那样导出整个工作表。 谢谢。
将范围复制到新工作簿中的新工作表。 另存为。 关。
Dim myCSVFileName As String
Dim tempWB As Workbook
myCSVFileName = ThisWorkbook.Path & "\" & "EXPORT_" & VBA.Format(VBA.Now, "ddMMyyyy") & ".csv"
'Create new Workbook.
Set tempWB = Workbooks.Add
'Copy Range
ThisWrokbook.Sheets("SheetNameWithRange").Range("A1:Z40").Copy
With tempWB
'Paste Range
.Worksheets(1).Range("A1").Paste 'Or Paste as Values to not retain Links/Formulas
'Save and Close
.SaveAs FileName:=myCSVFileName, FileFormat:=xlCSV, CreateBackup:=False
.Close
End With
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.