Как переименовать все файлы изображений в папке согласно списку ячеек в Excel?
Приходилось ли вам когда-нибудь переименовывать несколько изображений в папке на основе списка имен в листе Excel? Переименование их по одному может занять много времени, но с помощью кодов VBA вы можете быстро автоматизировать этот процесс.
Переименовать все файлы изображений в папке
Переименовать все файлы изображений в папке
Чтобы переименовать все файлы изображений в указанной папке, следуйте этим шагам:
Шаг 1: Импортируйте оригинальные имена файлов из папки в лист Excel
1. Нажмите клавиши «Alt + F11», чтобы открыть окно «Microsoft Visual Basic для приложений».
2. Щелкните «Вставить» > «Модуль» и вставьте приведенный ниже код в скрипт.
VBA: Получить названия изображений из папки
Sub PictureNametoExcel()
'UpdatebyExtendoffice201709027
Dim I As Long
Dim xRg As Range
Dim xAddress As String
Dim xFileName As String
Dim xFileDlg As FileDialog
Dim xFileDlgItem As Variant
On Error Resume Next
xAddress = ActiveWindow.RangeSelection.Address
Set xRg = Application.InputBox("Select a cell to place name list:", "KuTools For Excel", xAddress, , , , , 8)
If xRg Is Nothing Then Exit Sub
Application.ScreenUpdating = False
Set xRg = xRg(1)
xRg.Value = "Picture Name"
With xRg.Font
.Name = "Arial"
.FontStyle = "Bold"
.Size = 10
End With
xRg.EntireColumn.AutoFit
Set xFileDlg = Application.FileDialog(msoFileDialogFolderPicker)
I = 1
If xFileDlg.Show = -1 Then
xFileDlgItem = xFileDlg.SelectedItems.Item(1)
xFileName = Dir(xFileDlgItem & "\")
Do While xFileName <> ""
If InStr(1, xFileName, ".jpg") + InStr(1, xFileName, ".png") + InStr(1, xFileName, ".img") + InStr(1, xFileName, ".gif") + InStr(1, xFileName, ".ioc") + InStr(1, xFileName, ".bmp") > 0 Then
xRg.Offset(I).Value = xFileDlgItem & "\" & xFileName
I = I + 1
End If
xFileName = Dir
Loop
End If
Application.ScreenUpdating = True
End Sub
3. Нажмите клавишу «F5», чтобы запустить код, и появится диалоговое окно, которое напомнит вам выбрать ячейку для вывода списка имен. См. скриншот:
4. Нажмите «ОК» и выберите нужную папку, имена изображений которой необходимо перечислить в текущем листе. См. скриншот:
5. Нажмите «ОК». Имена изображений будут перечислены на активном листе.
Шаг 2: Переименуйте файлы изображений на основе нового списка имен
1. Нажмите клавиши «Alt + F11», чтобы открыть окно «Microsoft Visual Basic для приложений».
2. Щелкните «Вставить» > «Модуль» и вставьте приведенный ниже код в скрипт.
VBA: Переименовать файлы изображений в папке
Sub RenameFile()
'UpdatebyExtendoffice20170927
Dim I As Long
Dim xLastRow As Long
Dim xAddress As String
Dim xRgS, xRgD As Range
Dim xNumLeft, xNumRight As Long
Dim xOldName, xNewName As String
On Error Resume Next
xAddress = ActiveWindow.RangeSelection.Address
Set xRgS = Application.InputBox("Select Original Names(Single Column):", "KuTools For Excel", xAddress, , , , , 8)
If xRgS Is Nothing Then Exit Sub
Set xRgD = Application.InputBox("Select New Names(Single Column):", "KuTools For Excel", , , , , , 8)
If xRgD Is Nothing Then Exit Sub
Application.ScreenUpdating = False
xLastRow = xRgS.Rows.Count
Set xRgS = xRgS(1)
Set xRgD = xRgD(1)
For I = 1 To xLastRow
xOldName = xRgS.Offset(I - 1).Value
xNumLeft = InStrRev(xOldName, "\")
xNumRight = InStrRev(xOldName, ".")
xNewName = xRgD.Offset(I - 1).Value
If xNewName <> "" Then
xNewName = Left(xOldName, xNumLeft) & xNewName & Mid(xOldName, xNumRight)
Name xOldName As xNewName
End If
Next
MsgBox "Congratulations! You have successfully renamed all the files", vbInformation, "KuTools For Excel"
Application.ScreenUpdating = True
End Sub
3. Нажмите клавишу «F5», чтобы запустить код, и появится диалоговое окно, которое напомнит вам выбрать оригинальные имена изображений, которые вы хотите заменить. См. скриншот:
4. Нажмите «ОК» и выберите новые имена, которыми вы хотите заменить имена изображений во втором диалоговом окне. См. скриншот:
5. Нажмите «ОК», появится диалоговое окно, которое сообщит вам, что имена изображений были успешно изменены.
6. Нажмите «ОК», и имена изображений в папке будут заменены новыми именами из ячеек на листе.
![]() |
![]() |
![]() |
Связанные статьи:
Лучшие инструменты для повышения продуктивности работы с Office
Ускорьте работу в Excel с Kutools для Excel и ощутите новую степень эффективности. Kutools для Excel предлагает более300 расширенных функций для повышения продуктивности и экономии времени. Нажмите здесь, чтобы выбрать нужную вам функцию...
Office Tab добавляет вкладки в Office и делает вашу работу намного проще
- Включите редактирование и чтение с вкладками в Word, Excel, PowerPoint, Publisher, Access, Visio и Project.
- Открывайте и создавайте несколько документов во вкладках одного окна, а не в отдельных окнах.
- Увеличьте свою продуктивность на50% и сократите сотни лишних кликов мышью каждый день!