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

좋은 웹페이지 즐겨찾기