将excel工作区的表转换成csv文件

该文章的背景:
将配置文件写入数据库中 需要转成csv文件 xls 文件不能直接读取

参考链接 :
https://trumpexcel.com/vba-ranges/ 获取到当前可用的区域
Sub CopyCurrentRegion()
Range(“A1”, Range(“A1”).End(xlDown)).Copy Worksheets(“Sheet2”).Range(“A1”)
End Sub
将工作表转换为csv 文件链接
http://learnexcelmacro.com/wp/2017/09/save-excel-range-data-as-csv-file-through-excel-vba/#save-activeWorkSheet-as-CSV-file

	Sub saveRangeToCSV()
	
		Dim myCSVFileName As String
		Dim myWB As Workbook
		Dim tempWB As Workbook
		Dim rngToSave As Range
	
		Application.DisplayAlerts = False
		On Error GoTo err
	
		Set myWB = ThisWorkbook
		myCSVFileName = myWB.Path & "\" & "CSV-Exported-File-" & VBA.Format(VBA.Now, "dd-MMM-yyyy hh-mm") & ".csv"
	
		Set rngToSave = Range("C3:H50")
		rngToSave.Copy
	
		Set tempWB = Application.Workbooks.Add(1)
		With tempWB
			.Sheets(1).Range("A1").PasteSpecial xlPasteValues
			.SaveAs Filename:=myCSVFileName, FileFormat:=xlCSV, CreateBackup:=False
			.Close
		End With
		err:
		Application.DisplayAlerts = True
	End Sub

改过的实现代码

    Application.DisplayAlerts = False
    Dim myWB As Workbook
    Set myWB = ThisWorkbook
    Dim rngToSave As Range
     Dim mySheet As Worksheet
    Set mySheet = ActiveSheet
    '选中从A1到最大列的最大行的最后一个
    Set rngToSave = Range("A1", Range("A1").End(xlDown).End(xlToRight))
    '复制一份
    rngToSave.copy
    
    Dim tempWB As Workbook
    Set tempWB = Application.Workbooks.Add(1)
    With tempWB
        .Sheets(1).Range("A1").PasteSpecial xlPasteValues
        .SaveAs Filename:=myWB.Path & "\" & mySheet.Name, FileFormat:=xlCSV, CreateBackup:=False
        .Close
    End With
err:
    Application.DisplayAlerts = True
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值