def excel_refresh_query_replace(path, query_list = [], old_str = '', replacement_str = '', index_update = False, max_bk_date = '', sub_list = []):
Application = Dispatch("Excel.Application")
#Application.DisplayAlerts = False
#opens the excel file
wb = Application.Workbooks.Open(path)
if wb.ReadOnly:
wb.Close(False)
try:
os.system("taskkill /f /im excel.exe")
time.sleep(5)
except:
pass
return True
#if variables passed in then replace in query string
if query_list != []:
for query_name in query_list:
#existing query is initialized
current_q = wb.Queries(f"{query_name}").Formula
#replace string requires the new string as well as the old string to be replaces
new_q = current_q.replace(old_str,replacement_str)
wb.Queries(f"{query_name}").Formula = new_q
#refresh
wb.RefreshAll()
Application.CalculateUntilAsyncQueriesDone()
if sub_list != []:
for sub_name in sub_list:
Application.Run("sub_name")
#Updates the Index tab if required
if index_update:
wb.Sheets("Index").Range("E5").Value = f"Last Updated: {datetime.now().strftime('%d/%m/%Y')}"
if max_bk_date != '':
wb.Sheets("Index").Range("E6").Value = f"Last Booking Date Updated: {max_bk_date}"
#Save & Close
wb.Close(True)
try:
os.system("taskkill /f /im excel.exe")
time.sleep(5)
except:
pass
return False
Эта функция работает нормально, но из-за большого объема данных при передаче нескольких запросов она не обновляет все файлы. Я обновляю около 500 файлов, и около 70 файлов не обновляются полностью. У меня возникает проблема «Данные не полностью загружены». Он обновляется совершенно нормально, когда я пытаюсь обновить отдельный запрос вручную. Любые предложения по обновлению запросов по отдельности.
Пробовал wb.Queries(f"{query_name}").Refresh(), но выдает следующую ошибку
wb.Queries(query_name).Refresh() File "", line 2, in Refresh pywintypes.com_error: (-2147352567, 'Exception occurred.', (0, None, None, None, 0, -2146827284), None)```
ps: I am using a query connection from SQL server
Подробнее здесь: https://stackoverflow.com/questions/790 ... g-win32com
Обновление Excel с помощью Win32com ⇐ Python
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Как я могу переключить фрагмент сводной таблицы в Excel с помощью win32com, Python?
Anonymous » » в форуме Python - 0 Ответы
- 21 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Установка метки чувствительности для Excel с использованием Win32com (Python)
Anonymous » » в форуме Python - 0 Ответы
- 14 Просмотры
-
Последнее сообщение Anonymous
-