Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 25.07.2024
Сообщений: 4
Excel

Повреждается файл при загрузке на Sharepoint через VBA

23.01.2026, 10:09. Показов 494. Ответов 6

Студворк — интернет-сервис помощи студентам
Всем добрый день!
Бьюсь с проблемой уже больше недели, и пока безрезультатно.
В чем суть: разрабатываю в экселе процедуру, которая будет собирать данные из формы, формировать по шаблону новый файл, и загружать его в Sharepoint. Основная часть локально работает отлично, на компьютер файлы сохраняются без проблем. Но после загрузки в Sharepoint файл открыть не удается. Пробовал и на xlsx и на pdf файлах - не открываются.

Код процедуры загрузки под спойлером

Кликните здесь для просмотра всего текста

Visual Basic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
Sub UploadFileToSharePoint2()
 
Dim fileName As String
Dim filePath As String
Dim sharePointURL As String
Dim objHTTP As Object
 
'Set the file path and SharePoint URL
fileName = "Имяфайла.xlsx"
filePath = "Путь к файлу" & fileName
 
sharePointURL = "https://SharepointURL" & fileName
 
'Create an instance of the MSXML2.XMLHTTP object
' Примерно отсюда и ниже для меня конструкции малопонятные
 
Set objHTTP = CreateObject("MSXML2.XMLHTTP")
 
'Open the HTTP request
objHTTP.Open "PUT", sharePointURL, False
 
'Set the request headers
'objHTTP.setRequestHeader "Content - Type", "application / octet - stream"
'objHTTP.setRequestHeader "If - None - Match", " * "
objHTTP.setRequestHeader "Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
objHTTP.setRequestHeader "If-None-Match", "*"
objHTTP.setRequestHeader "X-FORMS_BASED_AUTH_ACCEPTED", "f"
objHTTP.setRequestHeader "Content-Length", CStr(FileLen(filePath))
 
'Send the file data
 
'Send the file data - ИСПРАВЛЕННЫЙ ВАРИАНТ 1 (с ADODB.Stream)
Dim stream As Object
Set stream = CreateObject("ADODB.Stream")
stream.Type = 1 ' adTypeBinary
stream.Open
stream.LoadFromFile filePath
objHTTP.Send stream.Read
stream.Close
 
'objHTTP.send CreateObject("Scripting.FileSystemObject").OpenTextFile(filePath, 1).ReadAll
 
'Check the response status
If objHTTP.Status = 200 Or objHTTP.Status = 201 Then
    MsgBox "File uploaded successfully!"
Else
    MsgBox "Error uploading file. Status: " & objHTTP.Status
End If
 
'Clean up
Set objHTTP = Nothing
End Sub


К сожалению протестировать этот код не так просто, доступ к шаре ограниченный.
Я совсем слабо понимаю в протоколе http. Половина процедуры слеплена из найденного в сети, и советов нейронки для устранения ошибок.
Предупреждая возможные вопросы - SharepointURL формируется корректно, файл попадает куда нужно.
Пробовал вместо MSXML2.XMLHTTP использовать CreateObject("WinHttp.WinHttpRequest.5.1 "), но через него не смог вообще ничего загрузить - получаю ошибку "Превышено время ожидания запроса", или как то так.
Получение длины файла через size = fso.GetFile(filePath).size тоже попробовал, ничего не дало.
Среди закомментированных строк видны еще некоторые опробованные варианты, но результат пока один.
Выручайте советом, блуждаю во тьме.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.01.2026, 10:09
Ответы с готовыми решениями:

Программа для заполнения таблицы в Sharepoint 2010
Здравствуйте, Пишу такую программу в которой есть, к примеру ячейка памяти с какими-то данными...

250 файлов *.pdf перенести с папки на диске в папки SharePoint
Всех приветствую! Уважаемые форумчане, нужна консультация в плане разработки для обычного...

Обращение к SharePoint
Добрый день! Подскажите, пожалуйста, кто знает, как решить данную проблему. Суть в следующем:...

6
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38174 / 21109 / 4307
Регистрация: 12.02.2012
Сообщений: 34,711
Записей в блоге: 14
24.01.2026, 07:05
В строке 12 формируется URL... Он формируется правильно? Если смотреть на код, то получится что-то вроде:

https://sharepintURLимя_файла

Это странно... Командная строка браузера при загрузке скорее всего должна иметь вид: параметр=имя_файла. И как выглядит "параметр" нужно знать.

Мне кажется, лучше пойти другим путём
1
0 / 0 / 0
Регистрация: 25.07.2024
Сообщений: 4
24.01.2026, 10:11  [ТС]
Сам по себе URL верный. Я формирую его в отдельной функции исходя из структуры папок, где мне необходимо разместить файл. Включена конвертация UTF-8, слэш перед именем файла в URL добавлен еще в функции.
И самое главное - процедура отрабатывает, файл попадает в нужное место.
Нужен ли там этот "параметр" - я не знаю, процедура это гибрид из вайб-кодинга и найденного в сети.

Основная проблема в том, что Sharepoint несмотря на мои попытки передачи файла и как потока бинарных данных (в процедуре эти строки закомментированы, но результат одинаков), и как xlsx документа, вмешивается и вносит изменения в структуру xlsx.

Загружаемые xslx файлы в файле Content_Types.xml получают дополнительные строки

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types">
<Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/>
<Default Extension="xml" ContentType="application/xml"/>
<Override PartName="/xl/workbook.xml" ContentType="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+ xml"/>
<Override PartName="/xl/worksheets/sheet1.xml" ContentType="application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+x ml"/>
<Override PartName="/xl/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/>
<Override PartName="/xl/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml"/>
<Override PartName="/xl/sharedStrings.xml" ContentType="application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrin gs+xml"/>
<Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/>
<Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/>
<Override PartName="/customXml/itemProps2.xml" ContentType="application/vnd.openxmlformats-officedocument.customXmlProperties+xml"/>
<Override PartName="/customXml/itemProps1.xml" ContentType="application/vnd.openxmlformats-officedocument.customXmlProperties+xml"/>
<Override PartName="/customXml/itemProps3.xml" ContentType="application/vnd.openxmlformats-officedocument.customXmlProperties+xml"/>
<Override PartName="/docProps/custom.xml" ContentType="application/vnd.openxmlformats-officedocument.custom-properties+xml"/>

</Types>
В результате эксель ругается, предлагает восстановить, но восстановление не дает результата.
Если удалить строки вручную - ругается все равно, но восстановление срабатывает успешно.
C PDF файлами видимо схожая проблема - размер совпадает плюс минус небольшое отклонение, а вместо файла скачиваю белые листы.

Пока родился только костыль - передавать файл как zip архив, даже без архивации, а просто меняя ему имя. После загрузки в коде меняю загруженному файлу на Sharepoint имя обратно. Первые пробы обнадеживающие.

Поизучаю метод передачи через PowerShell из ссылки выше, но он не поддерживается VBA напрямую, и могут быть подводные камни.

Хотелось бы надеяться, что есть какая-то волшебная команда типа "objHTTP.setRequestHeader "НЕ ЛЕЗЬ В МОЙ ФАЙЛ"", чтобы грузить любые файлы без танцев с бубном.
0
1386 / 842 / 91
Регистрация: 08.02.2017
Сообщений: 3,588
Записей в блоге: 1
24.01.2026, 12:11
Цитата Сообщение от sp1ash Посмотреть сообщение
Основная проблема в том, что Sharepoint несмотря на мои попытки передачи файла и как потока бинарных данных (в процедуре эти строки закомментированы, но результат одинаков), и как xlsx документа, вмешивается и вносит изменения в структуру xlsx.
Может быть дело в этом?
Цитата Сообщение от sp1ash Посмотреть сообщение
objHTTP.setRequestHeader "Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
0
0 / 0 / 0
Регистрация: 25.07.2024
Сообщений: 4
24.01.2026, 12:20  [ТС]
Цитата Сообщение от testuser2 Посмотреть сообщение
Может быть дело в этом?
Я пробовал оба варианта, закомментированные строки это вариант загрузки как бинарные данные
Visual Basic
1
2
'objHTTP.setRequestHeader "Content - Type", "application / octet - stream"
'objHTTP.setRequestHeader "If - None - Match", " * "
А в текущем варианте загрузка как xlsx.
Visual Basic
1
objHTTP.setRequestHeader "Content-Type", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"
Вот только результат не меняется, новые строки в Content_Types.xml появляются в обоих вариантах
0
1386 / 842 / 91
Регистрация: 08.02.2017
Сообщений: 3,588
Записей в блоге: 1
24.01.2026, 13:02
Цитата Сообщение от sp1ash Посмотреть сообщение
objHTTP.Open "PUT", sharePointURL, False
Вообще в этом методе есть еще два параметра. Если подключить в референсах библиотеку msxml6.ocx (C:\Windows\SysWOW64(или System32)\msxml6.dll) и назначить objHTTP тип MSXML2.XMLHTTP60
то сигнатура у метода Open будет такая
Visual Basic
1
2
3
Sub open(bstrMethod As String, bstrUrl As String, [varAsync], [bstrUser], [bstrPassword])
    Member of MSXML2.XMLHTTP60
    Open HTTP connection
При этом тип обекта objHTTP (typename(objHTTP)) после инициализации определяется как IServerXMLHTTPRequest2
Вот здесь для метода Open данного типа запроса в описании первого аргумента указаны допустимые значения только "GET" или "POST" (нету "PUT")
pwszMethod[in, string, ref]
The HTTP method used to open the connection, such as GET or POST.
Добавлено через 12 минут
Хотя я могу ошибаться. Вообще да, Power Shell или какой-нибуд Pithon может быть поинтересней в таких делах.
1
0 / 0 / 0
Регистрация: 25.07.2024
Сообщений: 4
24.01.2026, 14:29  [ТС]
"such as", мне кажется, означает "такие как" или "например", т.е. это не исчерпывающий список возможных параметров.
Нейронка говорит:
"Method (строка) - HTTP метод:
Основные: "GET", "POST", "PUT", "DELETE", "HEAD"
Другие: "PATCH", "OPTIONS", "TRACE", "CONNECT"
Для SharePoint REST API часто используются:
"GET" - получение данных
"POST" - создание элементов/файлов
"PUT" - обновление файлов
"DELETE" - удаление
"MERGE" или "PATCH" - частичное обновление элементов списка.
Подключить Python в принципе тоже вариант, писал на нем немного, но тогда работоспособность на разных машинах будет сложно обеспечить.
Буду пока изучать варианты, которые предложены
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.01.2026, 14:29
Помогаю со студенческими работами здесь

Купил книгу По VBA Программирование на VBA 2003 В.Г.Кузьменко
Поздравьте меня я купил книгу По VBA Программирование на VBA 2003 В.Г.Кузьменко, могу процитировать...

VBA Составить функцию VBA
помогите пожалуйста...

Vba excel windows и vba excel Mac Os - Макинтош корявит шрифт
Всем привет, столкнулся с такой ситуацией. Макросы написаны на Excel 2016 Windows. Когда файл...

VBA парсер выдает ошибку vba excel Run-time error '-2147319783 (80028019) и "microsoft ожидает пока другое приложение за
Добрый день, делаю свой первый парсер. Выдает ошибку vba excel Run-time error '-2147319783...

XLL хранение и выполнение VBA кода, или защита VBA кода от просмотра
Мое почтение, джентльмены... Делал для себя инструмент позволяющий хранить уже наработанный VBA...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru