29

私はVBコーディングに非常に慣れていません。複数のExcelファイルワークシートをcsvに保存しようとしています。複数のシートに対してこれを行うかどうかはわかりませんが、単一のファイルに対して行う方法を見つけました。このサイトで私がやろうとしていることに非常に役立つコードを見つけました。問題はファイルがワークシート名で保存されていることだけですが、元のファイルとワークシート名で保存しようとしていますfilename_worksheet name。それを自分で行いますが、エラーが発生し続けます。私が間違っていることを教えてください。

私が使用しているコードは次のとおりです。

   Public Sub SaveWorksheetsAsCsv()

   Dim WS As Excel.Worksheet
   Dim SaveToDirectory As String

   Dim CurrentWorkbook As String
   Dim CurrentFormat As Long

   CurrentWorkbook = ThisWorkbook.FullName
   CurrentFormat = ThisWorkbook.FileFormat
   ' Store current details for the workbook
   SaveToDirectory = "H:\test\"
   For Each WS In ThisWorkbook.Worksheets
   WS.SaveAs SaveToDirectory & WS.Name, xlCSV
   Next

Application.DisplayAlerts = False
ThisWorkbook.SaveAs Filename:=CurrentWorkbook, FileFormat:=CurrentFormat
Application.DisplayAlerts = True
' Temporarily turn alerts off to prevent the user being prompted
'  about overwriting the original file.

End Sub 
4

5 に答える 5

45

これがあなたが望むものだと思います...

Sub SaveWorksheetsAsCsv()

Dim WS As Excel.Worksheet
Dim SaveToDirectory As String

Dim CurrentWorkbook As String
Dim CurrentFormat As Long

CurrentWorkbook = ThisWorkbook.FullName
CurrentFormat = ThisWorkbook.FileFormat
' Store current details for the workbook
SaveToDirectory = "H:\test\"

For Each WS In Application.ActiveWorkbook.Worksheets
    WS.SaveAs SaveToDirectory & WS.Name, xlCSV
Next

Application.DisplayAlerts = False
ThisWorkbook.SaveAs Filename:=CurrentWorkbook, FileFormat:=CurrentFormat
Application.DisplayAlerts = True
' Temporarily turn alerts off to prevent the user being prompted
'  about overwriting the original file.

End Sub
于 2012-05-11T13:00:09.850 に答える
9

私も同様の問題を抱えていました。別のCSVファイルとして保存する必要があるワークシートのデータ。

これがコマンドボタンの背後にある私のコードです


Private Sub cmdSave()
    Dim sFileName As String
    Dim WB As Workbook

    Application.DisplayAlerts = False

    sFileName = "MyFileName.csv"
    'Copy the contents of required sheet ready to paste into the new CSV
    Sheets(1).Range("A1:T85").Copy 'Define your own range

    'Open a new XLS workbook, save it as the file name
    Set WB = Workbooks.Add
    With WB
        .Title = "MyTitle"
        .Subject = "MySubject"
        .Sheets(1).Select
        ActiveSheet.Paste
        .SaveAs "MyDirectory\" & sFileName, xlCSV
        .Close
    End With

    Application.DisplayAlerts = True
End Sub

これは私のために働きます:-)

于 2013-05-09T12:15:32.707 に答える
2

これはあなたがしようとしていることですか?

Option Explicit

Public Sub SaveWorksheetsAsCsv()
    Dim WS As Worksheet
    Dim SaveToDirectory As String, newName As String

    SaveToDirectory = "H:\test\"

    For Each WS In ThisWorkbook.Worksheets
        newName = GetBookName(ThisWorkbook.Name) & "_" & WS.Name
        WS.Copy
        ActiveWorkbook.SaveAs SaveToDirectory & newName, xlCSV
        ActiveWorkbook.Close Savechanges:=False
    Next
End Sub

Function GetBookName(strwb As String) As String
    GetBookName = Left(strwb, (InStrRev(strwb, ".", -1, vbTextCompare) - 1))
End Function
于 2012-05-11T12:58:19.360 に答える
1

マクロを記録して正確な手順を実行し、マクロが生成するVBAコードを確認するのが最善の方法です。次に、汎用的にしたいビット(つまり、ファイル名など)を置き換えます。

于 2012-05-11T13:04:56.227 に答える
1

上記のコードは、1つの小さな欠陥で完全に機能します。結果のファイルは、.csv拡張子で保存されません。–2日前のTensigh

以下をコードに追加すると、ファイルがcsvとして保存されました。このコードをありがとう。すべて期待どおりに機能しました。

ActiveWorkbook.SaveAs Filename:=SaveToDirectory & ThisWorkbook.Name & "-" & WS.Name & ".csv", FileFormat:=xlCSV
于 2014-06-17T16:01:18.843 に答える