前提・実現したいこと
会社のファイル管理がエクスプローラー→sharepointへ移行するに伴い、
VBAで①sharepoint上のファイルをダウンロード→②編集→③編集後のファイルをsharepointへアップロード
という一連の流れを自動化したいのですが、③だけうまく行きません。
③の作業内容:DesktopにあるBook3.xlsxをsharepoint上にBook2.xlsxとしてアップロード。
発生している問題・エラーメッセージ
実行時エラー'52' ファイル名または番号が不正です。
該当のソースコード
VBA
1Sub copy() 2 3Dim topath, frompath As String 4Dim obj As Object 5 6'path入力 7topath = "https://〇〇.sharepoint.com/sites/××/□□/test/Book2.xlsx" 8frompath = "C:\Users\△△\Desktop\Book3.xlsx" 9 10Set obj = CreateObject("Scripting.FileSystemObject") 11 12obj.Copyfile frompath, topath 13 14End Sub
試したこと
以下のリンクを参照し、URL→UNCパス変換を行いましたが、下記のエラーが出ました。
「②実行時エラー’76'
パスが見つかりません」
リンク:VBA Uploadfile
VBA
1Sub copy() 2 3Dim topath, frompath, topath2 As String 4Dim obj As Object 5 6'path入力 7topath = "https://〇〇.sharepoint.com/sites/××/□□/test/Book2.xlsx" 8frompath = "C:\Users\△△\Desktop\Book3.xlsx" 9topath2=ConvertDirectoryPath(topath) 10 11Set obj = CreateObject("Scripting.FileSystemObject") 12 13obj.Copyfile frompath, topath2 14 15End Sub 16 17Function ConvertDirectoryPath(path) As String 18 19 ConvertDirectoryPath = Replace(path, " ", "%20") 20 ConvertDirectoryPath = Replace(ConvertDirectoryPath, "/", "\") 21 ConvertDirectoryPath = Replace(ConvertDirectoryPath, "https:", "") 22 23End Function
補足情報(FW/ツールのバージョンなど)
ちなみに、topathの「https://〇〇.sharepoint.com/sites/××/□□/test」をIEのアドレスバーに打ち込むと、問題なくそのフォルダに飛んでくれます。
Windows10、Excel2016です。
初心者ですが、御教示のほど宜しくお願いします。
topath2はどのような値になっていますか?
ご質問有難うございます。
topath2=
\\〇〇.sharepoint.com@SSL\DavWWWRoot\sites\××\□□\test\Book2.xlsx
となっています。
そこにエクセルファイルを置いたあと、そのアドレスをエクスプローラーのアドレス欄に入れるとエクセルが開かれますか?
エクスプローラー上で、「\\〇〇.sharepoint.com@SSL\DavWWWRoot\sites\××\□□\test\Book2.xlsxにアクセスすることができません」とエラーがでます。
補足ですが、□□のフォルダ名にはスペースが入っており、そこは「スペース=%20」と表示されております。