質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

2回答

35664閲覧

VBAでsharepointへファイルをUploadする

hirozo

総合スコア4

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

1グッド

2クリップ

投稿2020/04/16 07:47

前提・実現したいこと

会社のファイル管理がエクスプローラー→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です。

初心者ですが、御教示のほど宜しくお願いします。

ka.saitoh👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

radames1000

2020/07/08 08:24

topath2はどのような値になっていますか?
hirozo

2020/07/08 09:27

ご質問有難うございます。 topath2= \\〇〇.sharepoint.com@SSL\DavWWWRoot\sites\××\□□\test\Book2.xlsx となっています。
radames1000

2020/07/09 00:33 編集

そこにエクセルファイルを置いたあと、そのアドレスをエクスプローラーのアドレス欄に入れるとエクセルが開かれますか?
hirozo

2020/07/09 05:13

エクスプローラー上で、「\\〇〇.sharepoint.com@SSL\DavWWWRoot\sites\××\□□\test\Book2.xlsxにアクセスすることができません」とエラーがでます。 補足ですが、□□のフォルダ名にはスペースが入っており、そこは「スペース=%20」と表示されております。
guest

回答2

0

SherePointに直接VBAからファイルの読み書きに行けなくなったようなので
「同期」によりOneDriveにフォルダを作成し、
VBAからはそのフォルダを指定すればいいようです。

ただし、同期の際に同期したOneDriveに更新権限が無いとエラーになります。

投稿2021/08/23 07:24

yuchizo

総合スコア6

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

https://〇〇.sharepoint.com/sites/××/□□/test
は、
FileSystemObjectで操作するときは
\〇〇.sharepoint.com@SSL\DavWWWRoot\sites\××\□□\test
になると思います。

投稿2020/07/07 09:43

daimazinezzz

総合スコア2

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hirozo

2020/07/08 07:54

ご回答いただき有難うございます。 ご教示の通り、下記のスクリプトを走らせました。 Sub copy() Dim topath As String Dim frompath As String Dim topath2 As String Dim obj As Object 'path入力 topath = "https:\〇〇.sharepoint.com@SSL\DavWWWRoot\sites\××\□□\test/Book2.xlsx" frompath = "C:\Users\△△\Desktop\Book3.xlsx" topath2 = ConvertDirectoryPath(topath) Set obj = CreateObject("Scripting.FileSystemObject") obj.Copyfile frompath, topath2※ End Sub Function ConvertDirectoryPath(path) As String ConvertDirectoryPath = Replace(path, " ", "%20") ConvertDirectoryPath = Replace(ConvertDirectoryPath, "/", "\") ConvertDirectoryPath = Replace(ConvertDirectoryPath, "https:", "") End Function すると、※部分にハイライトがかかり 「実行時エラー53 ファイルが見つかりません」 と出ます。 path2の部分をデスクトップ上の任意のフォルダ(ファイルの絶対参照)に設定するとうまくコピーされるので、やはり原因はsharepointのurlだと推測しています。 原因や解決策に関して、ほかに何かあれば是非ご教示頂きたいです。 宜しくお願い致します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問