Показать полную графическую версию : Excel | Название свернутого окна на панели задач
alinusik
21-01-2010, 14:13
Настроила отображение каждого документа в новом окне. Если открыто немного окон, то название открытого файла видно (Microsoft Excel-123.xlsm) Если же окон набирается достаточное кол-во, то уже сложно различать какой где документ открыт, т.к. названия обрезаются и видно лишь часть слова Microsoft. Можно ли как-то настроить Excel, чтобы название окна сразу начиналось с названия открытого документа?
Pliomera
29-01-2011, 00:41
alinusik, Camill, средствами Excel - невозможно. С использованием программирования и API - наверняка решаемо. Не проще ли расширить панель задач или не открывать много окон?
Если критично, что называется "до зарезу" - купите монитор на 45 дюймов :)
На самом деле в 2007 экселе эта проблема решалась - при открытии второй книги эксель ставил в заголовке название файла вперед, а при ее закрытии забывал сменить обратно. Соответственно, спасал макрос:
Set wb = Workbooks.Add
wb.Activate
ActiveWindow.Close
В 2010 склероз вылечили, а я уже несколько файлов переделал под новые контролы, и переставлять обратно 2007 не хочется.
WinAPI - это мысль, попробую. Получится - отпишусь.
Час моего времени, потраченного на ковыряние WinAPI, к сожалению, значительно дешевле монитора на 45 дюймов.
UPD
Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Public Declare Function SendMessage Lib "user32.dll" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByRef lParam As Any) As Long
Private Const WM_SETTEXT = &HC
Private Sub Workbook_Open()
УбратьПрефикс
End Sub
Sub УбратьПрефикс()
Dim hwnd As Long
Dim Заголовок as String
Заголовок = ActiveWorkbook.Name
hwnd = FindWindow(vbNullString, "Microsoft Excel - " & Заголовок)
if hwnd > 0 then SendMessage hwnd, WM_SETTEXT, 0, ByVal Заголовок
' OnTime нужен, так как через некоторое время эксель сам меняет заголовок обратно
Application.OnTime Now + TimeValue("00:00:10"), "УбратьПрефикс"
End Sub
Накидал тут на Delphi софтину. Скачиваете, добавляете в автозагрузку. Софтина удаляет в названии программ "Microsoft Excel - "
https://drive.google.com/file/d/1kTprGgTdNkdYznCqEFYLmYYi8Dn8KO6N/view?usp=sharing
v1va, без исходного кода? Такое себе…
© OSzone.net 2001-2012
vBulletin v3.6.4, Copyright ©2000-2025, Jelsoft Enterprises Ltd.
Available in ZeroNet 1osznRoVratMCN3bFoFpR2pSV5c9z6sTC