[英]Can I export only a range within a sheet using VBA?
I have only just started learning VBA and have built a small application that exports a particular sheet. 我刚开始学习VBA并构建了一个导出特定工作表的小应用程序。 I want to go one step further and only export a range from that sheet.
我想更进一步,只从该表中导出一个范围。
I've tried various different coding scenarios but to no avail. 我尝试了各种不同的编码方案,但无济于事。
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
Can anyone please confirm what code I would use to just export a range within a sheet? 任何人都可以确认我会用什么代码来导出工作表中的范围? I'm trying to export just the range A2:D24 in the sheet called "Data", rather than the whole sheet as what the current code above does.
我试图在名为“数据”的工作表中导出范围A2:D24,而不是像上面的当前代码那样导出整个工作表。 Thanks.
谢谢。
Copy Range to new Sheet in new Workbook. 将范围复制到新工作簿中的新工作表。 Save As.
另存为。 Close.
关。
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.