Задание имени файла excel

Excel для Microsoft 365 Excel 2021 Excel 2019 Excel 2016 Excel 2013 Excel 2010 Еще…Меньше

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

Вставка текущего имени файла, его полного пути и имени активного листа

Введите или вставьте следующую формулу в ячейку, в которой нужно отобразить текущее имя файла с полным путем и именем текущего листа.

=ЯЧЕЙКА(«filename»)

Вставка текущего имени файла и имени активного листа

Введите или вставьте следующую формулу в виде формула массива, чтобы отобразить текущее имя файла и имя активного листа.

=ПРАВСИМВ(ЯЧЕЙКА(«filename»);ДЛСТР(ЯЧЕЙКА(«filename»))- МАКС(ЕСЛИ(НЕ(ЕОШ(ПОИСК(«»;ЯЧЕЙКА(«filename»); СТРОКА(1:255))));ПОИСК(«»;ЯЧЕЙКА(«filename»);СТРОКА(1:255)))))

Примечания: 

  • Чтобы ввести формулу в виде формулы массива, нажмите клавиши CTRL+SHIFT+ВВОД.

  • Формула возвращает имя листа, если он был сохранен хотя бы один раз. Если вы используете эту формулу на несохраненном листе, ячейка формулы останется пустой, пока вы не сохраните лист.

Вставка только текущего имени файла

Введите или вставьте следующую формулу, чтобы вставить имя текущего файла в ячейку.

=ПСТР(ЯЧЕЙКА(«filename»);ПОИСК(«[«;ЯЧЕЙКА(«filename»))+1; ПОИСК(«]»;ЯЧЕЙКА(«filename»))-ПОИСК(«[«;ЯЧЕЙКА(«filename»))-1)

Примечание: Если вы используете эту формулу на несохраненном листе, вы увидите сообщение об ошибке #ЗНАЧ! в ячейке. После сохранения листа ошибка заменяется именем файла.

Дополнительные сведения

Вы всегда можете задать вопрос специалисту Excel Tech Community или попросить помощи в сообществе Answers community.

Нужна дополнительная помощь?

На каждый новый день задается файл с датой завтра. Внутри файла есть ячейка с формулой которая пишет завтрашнюю дату но если открывать файл который будет актуален через день то формула будет выводить не актуальную дату а завтрашнего числа.

Хочется сделать так чтобы название файла писалось в ячейке автоматом. тогда дата будет истинна.

На каждый новый день задается файл с датой завтра. Внутри файла есть ячейка с формулой которая пишет завтрашнюю дату но если открывать файл который будет актуален через день то формула будет выводить не актуальную дату а завтрашнего числа.

Хочется сделать так чтобы название файла писалось в ячейке автоматом. тогда дата будет истинна. koyaanisqatsi

Сообщение На каждый новый день задается файл с датой завтра. Внутри файла есть ячейка с формулой которая пишет завтрашнюю дату но если открывать файл который будет актуален через день то формула будет выводить не актуальную дату а завтрашнего числа.

Хочется сделать так чтобы название файла писалось в ячейке автоматом. тогда дата будет истинна. Автор — koyaanisqatsi
Дата добавления — 23.05.2014 в 14:44

Источник

Задание имени файла excel

Предположим, вы хотите вставить имя файла или путь к файлу в ячейку, верхний или нижний колонтитул Excel, как бы вы могли быстро выполнить эту операцию?

Вставить текущее имя файла или путь в ячейку с формулой

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

Товары Формула Пример
Только имя файла = MID (ЯЧЕЙКА («имя файла»), ПОИСК («[«, ЯЧЕЙКА («имя файла»)) + 1, ПОИСК («]», ЯЧЕЙКА («имя файла»)) — ПОИСК («[«, ЯЧЕЙКА («имя файла «)) — 1) продукты features.xlsx
Только путь к файлу = ЛЕВАЯ (ЯЧЕЙКА («имя файла»; A1); НАЙТИ («[«; ЯЧЕЙКА («имя файла»; A1); 1) -1) C: Users dt Desktop Новая папка
Только активное имя листа = ПРАВО (ЯЧЕЙКА («имя файла»), LEN (ЯЧЕЙКА («имя файла»)) — НАЙТИ («]», ЯЧЕЙКА («имя файла»), 1)) Sheet7
Текущее имя файла, путь к файлу и активное имя листа = ЯЧЕЙКА («имя файла») C: Users dt Desktop Новая папка [products features.xlsx] Sheet7

Ноты:

1. Скопируйте любую формулу выше, которая вам нужна, в указанную ячейку, и вы получите нужный результат.

2. Открытая книга должна быть сохранена.

Вставить текущее имя файла или путь в верхний / нижний колонтитул с помощью функции верхнего и нижнего колонтитула

Если вы хотите вставить имя файла или путь к файлу в верхний или нижний колонтитул рабочего листа, вы можете использовать функцию верхнего и нижнего колонтитула.

1. На ленте щелкните Вставить > Верхний и нижний колонтитулы.

2. В разделе верхнего или нижнего колонтитула будет три поля редактирования, нажмите оставил, центр or Ringht поле, в которое вы хотите вставить имя файла или путь. Тогда под Дизайн вкладку нажмите Путь к файлу, Имя файла or Имя листа что вам нужно вставить. Смотрите скриншот:

Затем щелкните любую ячейку, и вы увидите, что путь к файлу или имя или имя листа были вставлены в верхний или нижний колонтитул. Смотрите скриншоты:

Вставить текущее имя файла или путь в ячейку / верхний или нижний колонтитул с помощью Kutools for Excel

Kutools for ExcelАвтора Вставить информацию о книге это многофункциональный инструмент, он может помочь вам быстро и удобно вставить имя рабочего листа, имя книги, путь к книге или путь и имя книги в ячейки Excel, верхний или нижний колонтитул.

После установки Kutools for Excel, пожалуйста, сделайте, как показано ниже 🙁 Скачать бесплатно Kutools for Excel сейчас!)

1. Нажмите Кутулс Плюс > Рабочие инструменты > Вставить информацию о книге, см. снимок экрана:

2. В Вставить информацию о книге В диалоговом окне выберите информацию о книге, которую вы хотите вставить, на левой панели, а затем выберите место, куда вы хотите вставить информацию. Смотрите скриншот:

3. Затем нажмите OK. Если вы вставите информацию о wotkbook в ячейку, вы получите следующий результат:

Если вы вставляете информацию о книге в верхний или нижний колонтитул, вы можете выбрать место, куда вы хотите вставить информацию, левый, Правильно or Центр. И вы можете предварительно просмотреть верхний или нижний колонтитул из Вид > Макет страницы.

Чтобы узнать больше об этой функции, посетите Вставить информацию о книге.

Вставить информацию о книге

Наконечник.Если вы хотите вставить несколько пустых строк или столбцов в каждую n-ю строку, попробуйте использовать Kutools for Excel’s Вставить пустые строки и столбцы как показано на следующем снимке экрана. Полная функция без ограничений в течение 60 дней, пожалуйста, скачайте и получите бесплатную пробную версию сейчас.

Источник

Как на VBA сохранить файл Excel с названием, взятым из ячейки?

Привет, сейчас мы рассмотрим ситуацию, когда у Вас возникла необходимость в Excel сохранять файл с определенным названием, которое необходимо сформировать из значения ячейки или даже нескольких. В этой заметке я приведу простой пример реализации данной задачи.

Исходные данные

Сначала давайте разберем исходные данные, которые я буду использовать в примерах. Пусть это будет некая абстракция марок автомобилей с указанием их VIN номера.

Примечание! Я использую Excel 2013.

В зависимости от конкретных требований и условий, задачу можно реализовать по-разному, хотя принцип будет один и тот же, в этой статье мы рассмотрим несколько вариаций реализации.

Начнем мы с самой простой ситуации, когда заранее известна ячейка, на основе которой будет сформировано имя файла, и адрес этой ячейки изменяться не будет.

Сохранение файла Excel с названием из ячейки — с привязкой к этой ячейке

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

Ниже представлен код процедуры, я его подробно прокомментировал. Единственное скажу, что я во всех примерах сохраняю новые файлы без макросов (расширение .xlsx), т.е. по факту будет один файл с поддержкой макросов, а все производные — без.

Если нужно сохранять макрос в каждом файле, т.е. файлы с поддержкой макросов (расширение .xlsm), то необходимо просто указать другой тип файла при сохранении, а именно xlOpenXMLWorkbookMacroEnabled, в процедурах в комментариях я это указываю.

Открываем в Excel редактор Visual Basic, и вставляем код следующей процедуры в исходный код этой книги (ЭтаКнига, открыть двойным кликом) или в модуль, который Вы предварительно должны создать.

Примечание! Для того чтобы открыть редактор Visual Basic в Excel, необходимо перейти на вкладку «Разработчик» и нажать на кнопку «Visual Basic». Файл Excel с кодом процедуры необходимо сохранить с типом «Книга Excel с поддержкой макросов».

Код процедуры

После сохранения файла запустите макрос («Макросы -> Выполнить -> SaveFile»).

В результате в моем случае процедура успешно выполнилась, файл сохранился с названием «Марка Авто 1», данное значение взято из ячейки B14, о чем будет свидетельствовать сообщение в конце процедуры. Файл сохранен в каталоге, где и исходный файл (во всех примерах ниже прописано то же самое, т.е. сохранение рядом с исходником, но это Вы можете изменить).

Добавление кнопки в Excel для запуска макроса

Каждый раз открывать окно с макросами и выбирать нужный макрос не очень удобно, поэтому можно легко добавить кнопку где-нибудь рядом с данными и просто нажимать ее. Это делается следующим образом «Вкладка Разработчик -> Вставить -> Кнопка (элемент управления формы)».

Затем выберите место, где вставить кнопку, и нажмите туда. После этого появится окно назначения действия, т.е. нужно выбрать, какой макрос запускать при нажатии этой кнопки, выбираем наш макрос, т.е. SaveFile, и нажимаем «ОК».

В итоге появится кнопка с названием «Кнопка», это название лучше изменить, например, на «Сохранить файл». Для этого нажмите правой кнопкой мыши на кнопку и выберите настройки «Изменить текст». В итоге у Вас должно получиться что-то вроде этого.

Сохранение файла Excel с названием из ячейки — без привязки к ячейке

Теперь давайте представим, что заранее мы не можем определить, какая именно ячейка будет формировать название файла (может B14, а может и нет), поэтому мы можем немного скорректировать алгоритм таким образом, чтобы он брал значение из ячейки, которая является активной, но в этом случае Вы, конечно же, предварительно, должны выбрать ее (т.е. встать на нее).

Замените код процедуры следующим кодом, который совсем немного, но изменен.

Проверяем работу, становимся на нужную ячейку, и запускаем макрос (в процедуре я добавил проверку, если выбрана пустая ячейка, возникнет ошибка).

Как видим, все отработало.

Сохранение файла Excel с названием, которое сформировано из значений двух ячеек

Теперь представим, что нам нужно сформировать файл с названием из значений двух ячеек. Например, в нашем случае это может быть «Марка Авто – VIN Номер», в качестве разделителя я указал символ – (дефис), но им может выступать любой символ или вовсе отсутствовать.

В этом примере я покажу, как можно это реализовать с привязкой к конкретным ячейкам, в нашем случае B14 и D14.

Код процедуры в данном случае будет выглядеть следующим образом.

Все ОК, файл создан.

Если вдруг нужно реализовать без привязки к конкретным ячейкам, например, значения хранятся в определённых столбцах, но конкретная строка неизвестна Вам заранее. Например, у меня несколько строк со значениями, и какие конкретно значения взять за основу названия файла, я хочу указывать самостоятельно, непосредственно перед сохранением, но при этом не редактировать код процедуры.

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

Код процедуры

Становитесь на любую ячейку со значением в столбце B, и запускайте макрос.

У меня на этом все, надеюсь, материал был Вам полезен, пока!

Источник

Adblock
detector

Kutools for Excel, с более чем 300 удобные функции, облегчают вашу работу.
 

Микки

Пользователь

Сообщений: 3280
Регистрация: 24.12.2012

Добрый день , а есть функция выводящая имя файла и имя листа в ячейку? Лучше поотдельности.

 

subtlety

Пользователь

Сообщений: 375
Регистрация: 01.01.1970

 

Микки

Пользователь

Сообщений: 3280
Регистрация: 24.12.2012

я понимаю  что удф такую можно написать … но мне лучше функцию

 

Микки

Пользователь

Сообщений: 3280
Регистрация: 24.12.2012

Там для имени листа …  
=СПРАВА(ЯЧЕЙКА(«имя_файла»),ДЛСТР(ЯЧЕЙКА(«имя_файла»))- МАКС(ЕСЛИ(НЕ(ЕОШ(ПОИСК(«»,ЯЧЕЙКА(«имя_файла»), СТРОКА(1:255)))),ПОИСК(«»,ЯЧЕЙКА(«имя_файла»),СТРОКА(1:255)) у меня она не вводится а потом функции СПРАВА нет по -моему

 

subtlety

Пользователь

Сообщений: 375
Регистрация: 01.01.1970

Напишите просто:  
=ЯЧЕЙКА(«имяфайла»)  
А дальше разберетесь, как там отщипнуть.

 

Микки

Пользователь

Сообщений: 3280
Регистрация: 24.12.2012

=ПСТР(ЯЧЕЙКА(«имя_файла»),ПОИСК(«[«,ЯЧЕЙКА(«имя_файла»))+1, ПОИСК(«]»,ЯЧЕЙКА(«имя_файла»))-ПОИСК(«[«,ЯЧЕЙКА(«имя_файла»))-1)
эта оттуда же тоже не вводится…

 

Микки

Пользователь

Сообщений: 3280
Регистрация: 24.12.2012

=ЯЧЕЙКА(«имяфайла») кстати почему -то тоже не пашет

 

subtlety

Пользователь

Сообщений: 375
Регистрация: 01.01.1970

Посмотрите справку по этой функции.  
Может, у Вас аргумент другой нужен.  

  Если Excel новых (2007-2010) версий, наберите =ЯЧЕЙКА(  
и константы сами подсветятся

 

ShAM

Пользователь

Сообщений: 469
Регистрация: 05.01.2013

{quote}{login=Микки}{date=28.03.2012 12:34}{thema=}{post}=ПСТР(ЯЧЕЙКА(«имя_файла»),ПОИСК(«[«,ЯЧЕЙКА(«имя_файла»))+1, ПОИСК(«]»,ЯЧЕЙКА(«имя_файла»))-ПОИСК(«[«,ЯЧЕЙКА(«имя_файла»))-1)
эта оттуда же тоже не вводится…{/post}{/quote}  
Там точно так было, с запятыми и подчеркиванием?  
Попробуйте так.  
=ПСТР(ЯЧЕЙКА(«имяфайла»);ПОИСК(«[«;ЯЧЕЙКА(«имяфайла»))+1; ПОИСК(«]»;ЯЧЕЙКА(«имяфайла»))-ПОИСК(«[«;ЯЧЕЙКА(«имяфайла»))-1)

 

Вот — для возврата имени листа (офис 2010):  
=ПСТР(ЯЧЕЙКА(«ИМЯФАЙЛА»;A1);ПОИСК(«]»;ЯЧЕЙКА(«ИМЯФАЙЛА»;A1))+1;255)

 

Serge

Пользователь

Сообщений: 11308
Регистрация: 01.01.1970

Миш, универсально, для всех версий, всех локалей, волатильно:  

  Имя книги:    
=ПСТР(ЯЧЕЙКА(«filename»;A1);ПОИСК(«[«;ЯЧЕЙКА(«filename»))+1;НАЙТИ(«.xls»;ЯЧЕЙКА(«filename»))-ПОИСК(«[«;ЯЧЕЙКА(«filename»))-1)

  Имя листа:  
=ПРАВСИМВ(ЯЧЕЙКА(«filename»;A1);ДЛСТР(ЯЧЕЙКА(«filename»))-НАЙТИ(«]»;ЯЧЕЙКА(«filename»)))

 

Микки

Пользователь

Сообщений: 3280
Регистрация: 24.12.2012

Спасибо ShAM и гость ..получилось

 

ShAM

Пользователь

Сообщений: 469
Регистрация: 05.01.2013

 

Микки

Пользователь

Сообщений: 3280
Регистрация: 24.12.2012

#15

28.03.2012 15:00:09

Спасибо Сереж сохранил (в сердце)

Как вставить имя файла или путь в ячейку / верхний или нижний колонтитул в Excel?

Предположим, вы хотите вставить имя файла или путь к файлу в ячейку, верхний или нижний колонтитул Excel, как бы вы могли быстро выполнить эту операцию?

Вставить текущее имя файла или путь в ячейку с формулой

Вставить текущее имя файла или путь в верхний / нижний колонтитул с помощью функции верхнего и нижнего колонтитула

Вставьте текущее имя файла или путь в ячейку/верхний или нижний колонтитул с помощью Kutools for Excel хорошая идея3


стрелка синий правый пузырь Вставить текущее имя файла или путь в ячейку с формулой

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

Товары Формула Пример
Только имя файла = MID (ЯЧЕЙКА («имя файла»), ПОИСК («[«, ЯЧЕЙКА («имя файла»)) + 1, ПОИСК («]», ЯЧЕЙКА («имя файла»)) — ПОИСК («[«, ЯЧЕЙКА («имя файла «)) — 1) продукты features.xlsx
Только путь к файлу = ЛЕВАЯ (ЯЧЕЙКА («имя файла»; A1); НАЙТИ («[«; ЯЧЕЙКА («имя файла»; A1); 1) -1) C: Users dt Desktop Новая папка
Только активное имя листа = ПРАВО (ЯЧЕЙКА («имя файла»), LEN (ЯЧЕЙКА («имя файла»)) — НАЙТИ («]», ЯЧЕЙКА («имя файла»), 1)) Sheet7
Текущее имя файла, путь к файлу и активное имя листа = ЯЧЕЙКА («имя файла») C: Users dt Desktop Новая папка [products features.xlsx] Sheet7

Ноты:

1. Скопируйте любую формулу выше, которая вам нужна, в указанную ячейку, и вы получите нужный результат.

2. Открытая книга должна быть сохранена.


стрелка синий правый пузырь Вставить текущее имя файла или путь в верхний / нижний колонтитул с помощью функции верхнего и нижнего колонтитула

Если вы хотите вставить имя файла или путь к файлу в верхний или нижний колонтитул рабочего листа, вы можете использовать функцию верхнего и нижнего колонтитула.

1. На ленте щелкните Вставить > Верхний и нижний колонтитулы.

2. В разделе верхнего или нижнего колонтитула будет три поля редактирования, нажмите оставил, центр or Ringht поле, в которое вы хотите вставить имя файла или путь. Тогда под Дизайн вкладку нажмите Путь к файлу, Имя файла or Имя листа что вам нужно вставить. Смотрите скриншот:

документ-вставка-имя-файла-путь1

Затем щелкните любую ячейку, и вы увидите, что путь к файлу или имя или имя листа были вставлены в верхний или нижний колонтитул. Смотрите скриншоты:


стрелка синий правый пузырь Вставьте текущее имя файла или путь в ячейку/верхний или нижний колонтитул с помощью Kutools for Excel

Kutools for ExcelАвтора Вставить информацию о книге это многофункциональный инструмент, он может помочь вам быстро и удобно вставить имя рабочего листа, имя книги, путь к книге или путь и имя книги в ячейки Excel, верхний или нижний колонтитул.

После установки Kutools for Excel, пожалуйста, сделайте, как показано ниже :( Бесплатная загрузка Kutools for Excel Сейчас!)

1. Нажмите Кутулс Плюс > Рабочие инструменты > Вставить информацию о книге, см. снимок экрана:

документ вставить информацию о книге 3

2. В Вставить информацию о книге В диалоговом окне выберите информацию о книге, которую вы хотите вставить, на левой панели, а затем выберите место, куда вы хотите вставить информацию. Смотрите скриншот:

документ вставить информацию о книге 2

3. Затем нажмите OK. Если вы вставите информацию о wotkbook в ячейку, вы получите следующий результат:

документ-вставка-имя-файла-путь6

Если вы вставляете информацию о книге в верхний или нижний колонтитул, вы можете выбрать место, куда вы хотите вставить информацию, левый, Правильно or Центр. И вы можете предварительно просмотреть верхний или нижний колонтитул из Вид > Макет страницы.

Чтобы узнать больше об этой функции, посетите Вставить информацию о книге.

стрелка синий правый пузырь Вставить информацию о книге

Наконечник.Если вы хотите вставить несколько пустых строк или столбцов в каждую n-ю строку, попробуйте использовать Kutools for ExcelАвтора Вставить пустые строки и столбцы как показано на следующем снимке экрана. Полная функция без ограничений в течение 60 дней, пожалуйста, скачайте и получите бесплатную пробную версию сейчас.


Лучшие инструменты для работы в офисе

Kutools for Excel Решит большинство ваших проблем и повысит вашу производительность на 80%

  • Снова использовать: Быстро вставить сложные формулы, диаграммы и все, что вы использовали раньше; Зашифровать ячейки с паролем; Создать список рассылки и отправлять электронные письма …
  • Бар Супер Формулы (легко редактировать несколько строк текста и формул); Макет для чтения (легко читать и редактировать большое количество ячеек); Вставить в отфильтрованный диапазон
  • Объединить ячейки / строки / столбцы без потери данных; Разделить содержимое ячеек; Объединить повторяющиеся строки / столбцы… Предотвращение дублирования ячеек; Сравнить диапазоны
  • Выберите Дубликат или Уникальный Ряды; Выбрать пустые строки (все ячейки пустые); Супер находка и нечеткая находка во многих рабочих тетрадях; Случайный выбор …
  • Точная копия Несколько ячеек без изменения ссылки на формулу; Автоматическое создание ссылок на несколько листов; Вставить пули, Флажки и многое другое …
  • Извлечь текст, Добавить текст, Удалить по позиции, Удалить пробел; Создание и печать промежуточных итогов по страницам; Преобразование содержимого ячеек в комментарии
  • Суперфильтр (сохранять и применять схемы фильтров к другим листам); Расширенная сортировка по месяцам / неделям / дням, периодичности и др .; Специальный фильтр жирным, курсивом …
  • Комбинируйте книги и рабочие листы; Объединить таблицы на основе ключевых столбцов; Разделить данные на несколько листов; Пакетное преобразование xls, xlsx и PDF
  • Более 300 мощных функций. Поддерживает Office/Excel 2007-2021 и 365. Поддерживает все языки. Простое развертывание на вашем предприятии или в организации. Полнофункциональная 30-дневная бесплатная пробная версия. 60-дневная гарантия возврата денег.

вкладка kte 201905


Вкладка Office: интерфейс с вкладками в Office и упрощение работы

  • Включение редактирования и чтения с вкладками в Word, Excel, PowerPoint, Издатель, доступ, Visio и проект.
  • Открывайте и создавайте несколько документов на новых вкладках одного окна, а не в новых окнах.
  • Повышает вашу продуктивность на 50% и сокращает количество щелчков мышью на сотни каждый день!

офисный дно

In this guide, we’re going to show you how to get filename from path in Excel. We will cover how to do this with and without VBA.

Download Workbook

File path and file name

A file path is a string identifier that specifies the unique location in a file system. It contains folders in a hierarchical order following by a file name. Each element is separated by a delimiter which is usually a backslash «». The goal of getting filename from path is to parse that filename after the last delimiter.

Warning: If your paths contain another separator, update the formulas by replacing backslash («») with the separator character fits your case.

We will show you four different approaches to get filename from path in Excel.

Conservative method

Our first approach is using well known Excel functions MIN, SUBSTITUE and LEN to get the file name. You can use this formula in any Excel version.

=MID(<path>,FIND(«*»,SUBSTITUTE(<path>,»»,»*»,LEN(<path>)-LEN(SUBSTITUTE(<path>,»»,»»))))+1,LEN(<path>))

This formula has couple of steps:

  1. At the inner section, all separators («») get replaced with empty strings.
  2. The formula subtracts the length of substituted path (1) from original path to find the number of separators.
  3. The outer SUBSTITUTE function replaces the last separator («») with «*». Obviously, the last separator’s instance is equal to number of separators (2).
  4. Finally, the FIND locates the «*» character, and the MID function parses the file name after the character.

How to get filename from path in Excel 02 - Conservative

VBA with FileSystemObject

You can use VBA to create your own custom functions which you can use in worksheet as well. Of course, you can use this function in your macros as well.

The code is very short. It uses GetFileName method of FileSystemObject object. The important section of the code is the initializing of the object. The following code sets FileSystemObject object to fso variable.

Set fso = CreateObject(«Scripting.FileSystemObject»)

Once the object is initialized, use the GetFileName method by providing the path.

GetFileNameFromPath_FSO = fso.GetFileName(«C:Excel FilesDashboards.xlsm»)

The above line returns «Dashboard.xlsm» string. Here is the function version you can use in your worksheets as well.

Function GetFileNameFromPath_FSO(ByVal Path As String) As String
    Set fso = CreateObject("Scripting.FileSystemObject")
    GetFileNameFromPath_FSO = fso.GetFileName(Path)
End Function

How to get filename from path in Excel 03-VBA

VBA with a recursive function

A recursive function is function which calls itself. The recursive approach acts like an iteration and helps us to parse values starting from the end of a string. You could have used recursive functions only in VBA until the LAMBDA function has been released. Because the most of Excel users do not have access to the LAMBDA function, we will show you VBA version which any Excel user can use.

This function has only few rows as well. The function’s name is GetFilenameFromPath_Recursive and take a single argument named Path.

The first row is a logical test that checks if the last character in the argument is a backslash («») or not and if the argument is not an empty string. If the test is passed, the function returns itself with the argument without its last character and the last character of the path. This is where the recursion occurs.

The function runs itself until coming up a backslash («») or not a character left. It parses the characters from the right side and combines them with each run.

The last row contains a standard End If statement which determines where the If block ends.

Function GetFilenameFromPath_Recursive(ByVal Path As String) As String
    If Right$(Path, 1) <> "" And Len(Path) > 0 Then
        GetFilenameFromPath_Recursive = GetFilenameFromPath_Recursive(Left$(Path, Len(Path) - 1)) & Right$(Path, 1)
    End If
End Function

Using LAMBDA to get filename from path

If you are Microsoft 365 subscriber, you can create recursive functions without using VBA. Briefly, the LAMBDA function is a special function that converts named ranges into user defined functions. Its syntax allows you to define arguments and a custom formula which uses that defined arguments.

For example, let’s say my custom function will have two arguments and returns multiplication of two arguments. All I need to is creating a named range, such as «MyLambda» and enter the following formula into Refers to box.

Syntax Sample Formula Sample Result
=LAMBDA(x, y, x*y) =MyLambda(2,3) 6

If you call the named range «MyLambda» in the «MyLambda» function, you will create a recursive function. Same logic can be applied to VBA function at previous section.

The following is the LAMBDA version of our VBA code. The function’s name is GetFileNameFromPath_Lambda. Check out how the function calls itself after IF function’s logical test.

=LAMBDA(Path,IF(AND(RIGHT(Path,1)<>»»,LEN(Path)>0),GetFileNameFromPath_Lambda(LEFT(Path,LEN(Path)-1))&RIGHT(Path,1),»»))

Warning: Do not forget to update formula name in the formula if you change the named range’s name. Otherwise, the function returns #NAME? error due to incorrect function name.

Using LAMBDA Function with different approach

Alternatively, you can use the LAMBDA function without calling the «function name».  The definition may sound complicated since you must call the function in the function by its name. This structure dictates you to update each occurrence of the name every time change the function’s name.

You can overcome this necessity by using another Microsoft 365-specific function called LET. The LET function allows you to define named ranges in a formula scope. You can define repeating values or blocks into these names and use them continuously.

If you define the name of the LAMBDA function in the formula, you can use the in-formula name over and over to make the function recursive. In our example, we create the name «Func» in the formula and call it within self. Outer LAMBDA function is to give the whatever name we want, «GetFileNameFromPath_LambdaMe».

=LAMBDA(Path,LET(Func,LAMBDA(ME,Path,IF(AND(RIGHT(Path,1)<>»»,LEN(Path)>0),ME(ME,LEFT(Path,LEN(Path)-1))&RIGHT(Path,1),»»)),Func(Func,Path)))

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

Для этого, в настройках на вкладке «Создание файлов» имеется поле «Маска для имен создаваемых файлов»:


 

При настройке маски, мы можем использовать все доступные коды полей, а также 3 специальных поля:

  •  {%filename%} — имя файла шаблона без расширения
  •  {%ext%} — расширение файла шаблона
  •  {%subfolder%} — подпапки (если шаблон находится не в самой папке ШАБЛОНЫ, а в одной из её подпапок)

По-умолчанию, в настройках программы задана маска {%str%} — {%filename%}.{%ext%}

Рассмотрим на примере, что обозначает каждый из 3 кодов в этой маске, и какие имена получат создаваемые файлы.

Предположим, что исходная таблица с данными у нас выглядит так:

ФИО Дата рождения ФИО сокр Номер договора Дата договора
Иванов Иван Иванович 09.02.1966 Иванов И.И. ОУ2011/1 01.12.2011
Купитман Иван Натанович 13.01.1970 Купитман И.Н. ОУ2011/3 03.12.2011
Кисегач Анастасия Константиновна 31.12.1971 Кисегач А.К. ОУ2011/4 04.12.2011
Черноус Варвара Николаевна 17.12.1973 Черноус В.Н. ОУ2011/5 05.12.2011
Быков Андрей Евгеньевич 04.12.1975 Быков А.Е. ОУ2011/6 06.12.2011

а в папке «ШАБЛОНЫ» у нас 3 файла:

  • Акт.doc
  • Приказ.doc
  • доверенность.xls

причем файл «доверенность.xls» находится в подпапке «разное»:

…ШаблоныАкт.doc
…ШаблоныПриказ.doc
…Шаблоныразноедоверенность.xls


При использовании маски имени файла {%str%} — {%filename%}.{%ext%},
имена получаемых файлов имеют следующий вид:

Маска имени файла Файл шаблона Имя созданного документа
Строка №2 (Иванов И.И.)    
{%str%} — {%filename%}.{%ext%} …ШаблоныАкт.doc …Документы2 — Акт.doc
…ШаблоныПриказ.doc …Документы2 — Приказ.doc
…Шаблоныразноедоверенность.xls …Документыразное2 — доверенность.xls
Строка №3 (Купитман И.Н.)    
{%str%} — {%filename%}.{%ext%} …ШаблоныАкт.doc …Документы3 — Акт.doc
…ШаблоныПриказ.doc …Документы3 — Приказ.doc
…Шаблоныразноедоверенность.xls …Документыразное3 — доверенность.xls

Как видите, код {%str%} заменяется на порядковый номер исходной строки на листе.

Это позволяет давать всем файлам уникальные (отличающиеся друг от друга) имена.


Чтобы в имена создаваемых файлов попала фамилия сотрудника,
можно применить, например, маску {%filename%} — {ФИО сокр}.{%ext%}:

Маска имени файла Имя файла-шаблона Имя файла созданного документа
Строка №2 (Иванов И.И.)    
{%filename%} — {ФИО сокр}.{%ext%} …ШаблоныАкт.doc …ДокументыАкт — Иванов И.И..doc
…ШаблоныПриказ.doc …ДокументыПриказ — Иванов И.И..doc
…Шаблоныразноедоверенность.xls …Документыразноедоверенность — Иванов И.И..xls
Строка №3 (Купитман И.Н.)    
{%filename%} — {ФИО сокр}.{%ext%} …ШаблоныАкт.doc …ДокументыАкт — Купитман И.Н..doc
…ШаблоныПриказ.doc …ДокументыПриказ — Купитман И.Н..doc
…Шаблоныразноедоверенность.xls …Документыразноедоверенность — Купитман И.Н..xls

или маску {ФИО}{%filename%}.{%ext%}

Маска имени файла Имя файла-шаблона Имя файла созданного документа
Строка №2 (Иванов И.И.)    
{ФИО}{%filename%}.{%ext%} …ШаблоныАкт.doc …ДокументыИванов Иван ИвановичАкт.doc
…ШаблоныПриказ.doc …ДокументыИванов Иван ИвановичПриказ.doc
…Шаблоныразноедоверенность.xls …ДокументыразноеИванов Иван Ивановичдоверенность.xls
Строка №3 (Купитман И.Н.)    
{ФИО}{%filename%}.{%ext%} …ШаблоныАкт.doc …ДокументыКупитман Иван НатановичАкт.doc
…ШаблоныПриказ.doc …ДокументыКупитман Иван НатановичПриказ.doc
…Шаблоныразноедоверенность.xls …ДокументыразноеКупитман Иван Натановичдоверенность.xls

Обратите внимание на обратный слеш () после кода {ФИО} — это позволяет создать подпапку,
имя которой соответствует тексту из заданного столбца.

В нашем примере, для каждого сотрудника в папке «Документы» была создана отдельная подпапка.

Таких слешей может быть сколько угодно, — например, ничто не мешает использовать маску типа {%date%}{%filename%}{ФИО}.{%ext%}

Маска имени файла Имя файла-шаблона Имя файла созданного документа
Строка №2 (Иванов И.И.)    
{%date%}{%filename%}{ФИО}.{%ext%} …ШаблоныАкт.doc …Документы2013-01-21АктИванов Иван Иванович.doc
…ШаблоныПриказ.doc …Документы2013-01-21ПриказИванов Иван Иванович.doc
…Шаблоныразноедоверенность.xls …Документыразное2013-01-21доверенностьИванов Иван Иванович.xls
Строка №3 (Купитман И.Н.)    
{%date%}{%filename%}{ФИО}.{%ext%} …ШаблоныАкт.doc …Документы2013-01-21АктКупитман Иван Натанович.doc
…ШаблоныПриказ.doc …Документы2013-01-21ПриказКупитман Иван Натанович.doc
…Шаблоныразноедоверенность.xls …Документыразное2013-01-21доверенностьКупитман Иван Натанович.xls

Таким образом, мы сгруппировали созданные файлы по дате создания (заполнения), а внутри папки (за текущую дату) — по типу документа (акт, приказ, и т.д.)

ДОБАВЛЕНО в феврале 2021:
Если надо группировать созданные файлы в папке сначала по полю (например, по фамилии), и уже внутри этих папок создавать подпапки (как они созданы в папке ШАБЛОНЫ), то можно применить в маске имени файла специальный подстановочный код {%subfolder%}:

Рассмотрим вариант с маской имени файла {ФИО}{%subfolder%}{%filename%}.{%ext%}

Маска имени файла Имя файла-шаблона Имя файла созданного документа
Строка №2 (Иванов И.И.)    
{ФИО}{%subfolder%}{%filename%}.{%ext%} …ШаблоныАкт.doc …ДокументыИванов Иван ИвановичАкт.doc
…ШаблоныприказыПриказ.doc …ДокументыИванов Иван ИвановичприказыПриказ.doc
…Шаблоныразноедоверенность.xls …ДокументыИванов Иван Ивановичразноедоверенность.xls
Строка №3 (Купитман И.Н.)    
{ФИО}{%subfolder%}{%filename%}.{%ext%} …ШаблоныАкт.doc …ДокументыКупитман Иван НатановичАкт.doc
…ШаблоныприказыПриказ.doc …ДокументыКупитман Иван НатановичприказыПриказ.doc
…Шаблоныразноедоверенность.xls …ДокументыКупитман Иван Натановичразноедоверенность.xls

Можно в маске имени файла использовать сразу несколько доступных кодов полей:

Маска имени файла Файл шаблона Имя созданного документа
Строка №2 (Иванов И.И.)    
{ФИО сокр} (по договору {Номер договора}) {%filename%}.{%ext%} …ШаблоныАкт.doc …ДокументыИванов И.И. (по договору ОУ2011_1) Акт.doc
…ШаблоныПриказ.doc …ДокументыИванов И.И. (по договору ОУ2011_1) Приказ.doc
…Шаблоныразноедоверенность.xls …ДокументыразноеИванов И.И. (по договору ОУ2011_1) доверенность.xls
Строка №3 (Купитман И.Н.)    
{ФИО сокр} (по договору {Номер договора}) {%filename%}.{%ext%} …ШаблоныАкт.doc …ДокументыКупитман И.Н. (по договору ОУ2011_3) Акт.doc
…ШаблоныПриказ.doc …ДокументыКупитман И.Н. (по договору ОУ2011_3) Приказ.doc
…Шаблоныразноедоверенность.xls …ДокументыразноеКупитман И.Н. (по договору ОУ2011_3) доверенность.xls

Можно добавлять данные из исходной таблицы Excel в имена отдельно выбранных файлов,
прописав коды полей прямо в именах файлов-шаблонов.

Для примера, переименуем наши шаблоны следующим образом:

  • Счёт ({ФИО сокр}) на {сумма договора} рублей.doc
  • доверенность — {ФИО}.xls
  • Договор {Номер договора} от {Дата договора}.doc

В этом случае, мы можем использовать простейшую маску имени файла {%filename%}.{%ext%}

Маска имени файла Файл шаблона Имя созданного документа
Строка №2 (Иванов И.И.)    
{%filename%}.{%ext%} …Шаблоныдоверенность — {ФИО}.xls …Документыдоверенность — Иванов Иван Иванович.xls
…ШаблоныДоговор {Номер договора} от {Дата договора}.doc …ДокументыДоговор ОУ2011_1 от 01.12.2011.doc
…ШаблоныСчёт ({ФИО сокр}) на {сумма договора} рублей.doc …ДокументыСчёт (Иванов И.И.) на 300,00 рублей.doc
Строка №3 (Купитман И.Н.)    
{%filename%}.{%ext%} …Шаблоныдоверенность — {ФИО}.xls …Документыдоверенность — Купитман Иван Натанович.xls
…ШаблоныДоговор {Номер договора} от {Дата договора}.doc …ДокументыДоговор ОУ2011_3 от 03.12.2011.doc
…ШаблоныСчёт ({ФИО сокр}) на {сумма договора} рублей.doc …ДокументыСчёт (Купитман И.Н.) на 320,30 рублей.doc

или же, комбинировать оба способа:

Маска имени файла Файл шаблона Имя созданного документа
Строка №2 (Иванов И.И.)    
{ФИО сокр} — {%filename%}.{%ext%} …Шаблоныдоверенность.xls …ДокументыИванов И.И. — доверенность.xls
…ШаблоныДоговор {Номер договора}{print=2}.doc …ДокументыИванов И.И. — Договор ОУ2011_1.doc
…ШаблоныСчёт ({сумма договора} руб.).doc …ДокументыИванов И.И. — Счёт ( 300,00 руб.).doc
Строка №3 (Купитман И.Н.)    
{ФИО сокр} — {%filename%}.{%ext%} …Шаблоныдоверенность.xls …ДокументыКупитман И.Н. — доверенность.xls
…ШаблоныДоговор {Номер договора}{print=2}.doc …ДокументыКупитман И.Н. — Договор ОУ2011_3.doc
…ШаблоныСчёт ({сумма договора} руб.).doc …ДокументыКупитман И.Н. — Счёт ( 320,30 руб.).doc

В последнем примере, мы применили маску {ФИО сокр} — {%filename%}.{%ext%},
а имена файлов-шаблонов были такими:

  • доверенность.xls
  • Договор {Номер договора}{print=2}.doc
  • Счёт ({сумма договора} руб.).doc

Обратите внимание на код поля {print=2} — это служебное поле, в имя создаваемого файла оно не попадает.

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

По-умолчанию, на печать выводится 1 копия документа (впрочем, количество копий можно задать в настройках программы, или же настроить, чтобы оно бралось из определённого столбца исходной таблицы Excel)

Используя код {print=x} (где x — целое число), можно указать программе количество печатных копий для отдельных файлов-шаблонов.

Привет, сейчас мы рассмотрим ситуацию, когда у Вас возникла необходимость в Excel сохранять файл с определенным названием, которое необходимо сформировать из значения ячейки или даже нескольких. В этой заметке я приведу простой пример реализации данной задачи.

Содержание

  1. Исходные данные
  2. Сохранение файла Excel с названием из ячейки — с привязкой к этой ячейке
  3. Добавление кнопки в Excel для запуска макроса
  4. Сохранение файла Excel с названием из ячейки — без привязки к ячейке
  5. Сохранение файла Excel с названием, которое сформировано из значений двух ячеек

Исходные данные

Сначала давайте разберем исходные данные, которые я буду использовать в примерах. Пусть это будет некая абстракция марок автомобилей с указанием их VIN номера.

Примечание! Я использую Excel 2013.

Скриншот 2

В зависимости от конкретных требований и условий, задачу можно реализовать по-разному, хотя принцип будет один и тот же, в этой статье мы рассмотрим несколько вариаций реализации.

Начнем мы с самой простой ситуации, когда заранее известна ячейка, на основе которой будет сформировано имя файла, и адрес этой ячейки изменяться не будет.

Заметка! Этапы разработки программы – как создаются и проектируются программы?

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

Ниже представлен код процедуры, я его подробно прокомментировал. Единственное скажу, что я во всех примерах сохраняю новые файлы без макросов (расширение .xlsx), т.е. по факту будет один файл с поддержкой макросов, а все производные — без.

Если нужно сохранять макрос в каждом файле, т.е. файлы с поддержкой макросов (расширение .xlsm), то необходимо просто указать другой тип файла при сохранении, а именно xlOpenXMLWorkbookMacroEnabled, в процедурах в комментариях я это указываю.

Открываем в Excel редактор Visual Basic, и вставляем код следующей процедуры в исходный код этой книги (ЭтаКнига, открыть двойным кликом) или в модуль, который Вы предварительно должны создать.

Примечание! Для того чтобы открыть редактор Visual Basic в Excel, необходимо перейти на вкладку «Разработчик» и нажать на кнопку «Visual Basic». Файл Excel с кодом процедуры необходимо сохранить с типом «Книга Excel с поддержкой макросов».

Код процедуры

   
   Sub SaveFile()

   'Объявление переменных
   Dim CellValue As String
   Dim Path As String
   Dim FinalFileName As String

   'Временно отключаем показ вспомогательных сообщений
   Application.DisplayAlerts = False

   'Задаём каталог сохранения файла (в данном случае текущий каталог)
   Path = ThisWorkbook.Path & ""

   'Получаем значение ячейки
   CellValue = Range("B14")

   'Формируем итоговый путь и название файла
   FinalFileName = Path & CellValue

   'Сохраняем файл
   ActiveWorkbook.SaveAs FileName:=FinalFileName, _
                      FileFormat:=xlOpenXMLWorkbook
                      'FileFormat:=xlOpenXMLWorkbookMacroEnabled 'Для сохранения файла с макросом

   'Включаем вывод сообщений
   Application.DisplayAlerts = True

   'Сообщение с результатом выполнения процедуры
   MsgBox "Файл успешно сохранен с названием - " & CellValue, vbInformation, "Результат"

  End Sub

После сохранения файла запустите макрос («Макросы -> Выполнить -> SaveFile»).

В результате в моем случае процедура успешно выполнилась, файл сохранился с названием «Марка Авто 1», данное значение взято из ячейки B14, о чем будет свидетельствовать сообщение в конце процедуры. Файл сохранен в каталоге, где и исходный файл (во всех примерах ниже прописано то же самое, т.е. сохранение рядом с исходником, но это Вы можете изменить).

Скриншот 3

Заметка! Статический анализ кода в теории и на практике.

Добавление кнопки в Excel для запуска макроса

Каждый раз открывать окно с макросами и выбирать нужный макрос не очень удобно, поэтому можно легко добавить кнопку где-нибудь рядом с данными и просто нажимать ее. Это делается следующим образом «Вкладка Разработчик -> Вставить -> Кнопка (элемент управления формы)».

Скриншот 4

Затем выберите место, где вставить кнопку, и нажмите туда. После этого появится окно назначения действия, т.е. нужно выбрать, какой макрос запускать при нажатии этой кнопки, выбираем наш макрос, т.е. SaveFile, и нажимаем «ОК».

Скриншот 5

Курс по SQL для начинающих

В итоге появится кнопка с названием «Кнопка», это название лучше изменить, например, на «Сохранить файл». Для этого нажмите правой кнопкой мыши на кнопку и выберите настройки «Изменить текст». В итоге у Вас должно получиться что-то вроде этого.

Скриншот 6

Заметка! ТОП 7 популярных языков программирования.

Сохранение файла Excel с названием из ячейки — без привязки к ячейке

Теперь давайте представим, что заранее мы не можем определить, какая именно ячейка будет формировать название файла (может B14, а может и нет), поэтому мы можем немного скорректировать алгоритм таким образом, чтобы он брал значение из ячейки, которая является активной, но в этом случае Вы, конечно же, предварительно, должны выбрать ее (т.е. встать на нее).

Замените код процедуры следующим кодом, который совсем немного, но изменен.

  
   Sub SaveFile()

  'Объявление переменных
   Dim CellValue As String
   Dim Path As String
   Dim FinalFileName As String

   'Временно отключаем показ вспомогательных сообщений
   Application.DisplayAlerts = False

   'Задаём каталог сохранения файла (в данном случае текущий каталог)
   Path = ThisWorkbook.Path & ""

   'Проверка значения ячейки
   If ActiveCell.Value = "" Then
     MsgBox "В ячейке отсутствует значение", vbCritical, "Ошибка!"
     Exit Sub
   End If

   'Получаем значение активной ячейки
   CellValue = ActiveCell.Value

   'Формируем итоговый путь и название файла
   FinalFileName = Path & CellValue

   'Сохраняем файл
   ActiveWorkbook.SaveAs FileName:=FinalFileName, _
                      FileFormat:=xlOpenXMLWorkbook
                      'FileFormat:=xlOpenXMLWorkbookMacroEnabled 'Для сохранения файла с макросом

   'Включаем вывод сообщений
   Application.DisplayAlerts = True

   MsgBox "Файл успешно сохранен с названием - " & CellValue, vbInformation, "Результат"

   End Sub

Проверяем работу, становимся на нужную ячейку, и запускаем макрос (в процедуре я добавил проверку, если выбрана пустая ячейка, возникнет ошибка).

Скриншот 7

Как видим, все отработало.

Сохранение файла Excel с названием, которое сформировано из значений двух ячеек

Теперь представим, что нам нужно сформировать файл с названием из значений двух ячеек. Например, в нашем случае это может быть «Марка Авто – VIN Номер», в качестве разделителя я указал символ – (дефис), но им может выступать любой символ или вовсе отсутствовать.

В этом примере я покажу, как можно это реализовать с привязкой к конкретным ячейкам, в нашем случае B14 и D14.

Код процедуры в данном случае будет выглядеть следующим образом.

   
   Sub SaveFile()

   'Объявление переменных
   Dim CellValue As String
   Dim Path As String
   Dim FinalFileName As String

   'Временно отключаем показ вспомогательных сообщений
   Application.DisplayAlerts = False

   'Задаём каталог сохранения файла (в данном случае текущий каталог)
   Path = ThisWorkbook.Path & ""

   'Проверка значения ячеек B14 и D14
   If Range("B14").Value = "" Or Range("D14").Value = "" Then
     MsgBox "В ячейке отсутствует значение", vbCritical, "Ошибка!"
     Exit Sub
   End If

   'Складываем значения из двух ячеек B14 и D14
   CellValue = Range("B14").Value & " - " & Range("D14").Value

   'Формируем итоговый путь и название файла
   FinalFileName = Path & CellValue

   'Сохраняем файл
   ActiveWorkbook.SaveAs FileName:=FinalFileName, _
                      FileFormat:=xlOpenXMLWorkbook
                      'FileFormat:=xlOpenXMLWorkbookMacroEnabled 'Для сохранения файла с макросом

   'Включаем вывод сообщений
   Application.DisplayAlerts = True

   MsgBox "Файл успешно сохранен с названием - " & CellValue, vbInformation, "Результат"

   End Sub

Запускаем макрос.

Скриншот 8

Все ОК, файл создан.

Заметка! Как измерить сложность кода программы при программировании?

Если вдруг нужно реализовать без привязки к конкретным ячейкам, например, значения хранятся в определённых столбцах, но конкретная строка неизвестна Вам заранее. Например, у меня несколько строк со значениями, и какие конкретно значения взять за основу названия файла, я хочу указывать самостоятельно, непосредственно перед сохранением, но при этом не редактировать код процедуры.

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

Код процедуры

   
   Sub SaveFile()

   'Объявление переменных
   Dim CellValue As String
   Dim Path As String
   Dim FinalFileName As String

   'Временно отключаем показ вспомогательных сообщений
   Application.DisplayAlerts = False

   'Задаём каталог сохранения файла (в данном случае текущий каталог)
   Path = ThisWorkbook.Path & ""

   'Проверка номера столбца
   If ActiveCell.Column <> 2 Then
     MsgBox "Указан некорректный столбец", vbCritical, "Ошибка!"
     Exit Sub
   End If

  'Проверка значения ячейки
   If ActiveCell.Value = "" Then
     MsgBox "В ячейке отсутствует значение", vbCritical, "Ошибка!"
     Exit Sub
   End If

   'Получаем значение активной ячейки
   CellValue = ActiveCell.Value

   'Смещаемся на 2 столбца, относительно активной ячейки
   ActiveCell.Offset(0, 2).Select

   'Складываем значения из двух ячеек
   CellValue = CellValue & " - " & ActiveCell.Value

   'Формируем итоговый путь и название файла
   FinalFileName = Path & CellValue

   'Сохраняем файл
   ActiveWorkbook.SaveAs FileName:=FinalFileName, _
                      FileFormat:=xlOpenXMLWorkbook
                      'FileFormat:=xlOpenXMLWorkbookMacroEnabled 'Для сохранения файла с макросом

   'Включаем вывод сообщений
   Application.DisplayAlerts = True

   MsgBox "Файл успешно сохранен с названием - " & CellValue, vbInformation, "Результат"

   End Sub

Становитесь на любую ячейку со значением в столбце B, и запускайте макрос.

Заметка! Опрос. Какой операционной системой Вы пользуетесь?

У меня на этом все, надеюсь, материал был Вам полезен, пока!

Понравилась статья? Поделить с друзьями:
  • Задание имени таблицы в excel
  • Задание имени рабочему листу excel
  • Задание зонтик в excel
  • Задание зависимости в excel
  • Задание документ microsoft word docx