Форум программистов, компьютерный форум, киберфорум VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.79/29: Рейтинг темы: голосов - 29, средняя оценка - 4.79
gde-site

Как определить адрес ячейки, в которой находится картинка?

17.07.2014, 20:58. Показов 5952. Ответов 1
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Задача такая: экспортировать все картинки из файла xlsx, который представляет собой каталог запчастей, полученный из PDF при помощи FineReader. И нужно, чтобы имена для названий файлов брались из ячеек, которые выше на 2 строки чем картинки.

Как экспортировать нашел на http://www.excel-vba.ru/chto-u... tinki-jpg/, но файлы сохраняются списком аля Picture1, Picture 2, Picture 3 и т.д.
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
Sub SavePix()
    Dim avFiles, li As Long, oObj As Object, wsSh As Worksheet, wsTmpSh As Worksheet
    Dim sBookName As String, sName As String
 
    avFiles = Application.GetOpenFilename("Excel Files(*.xls*),*.xls*", , "Выбрать файлы", , True)
    If VarType(avFiles) = vbBoolean Then Exit Sub
    
    On Error Resume Next
    Application.ScreenUpdating = False
    Application.DisplayAlerts = False
    Set wsTmpSh = ThisWorkbook.Sheets.Add
    For li = LBound(avFiles) To UBound(avFiles)
        Workbooks.Open avFiles(li)
        sBookName = ActiveWorkbook.Name
        For Each wsSh In Sheets
            For Each oObj In wsSh.Shapes
                If oObj.Type = 13 Then
                    '13 - картинки
                    '1 - автофигуры
                    '3 - диаграммы
                    oObj.Copy
                    sName = ActiveWorkbook.FullName & "_" & wsSh.Name & "_" & oObj.Name
                    With wsTmpSh.ChartObjects.Add(0, 0, oObj.Width, oObj.Height).Chart
                        .ChartArea.Border.LineStyle = 0
                        .Paste
                        .Export Filename:=sName & ".jpg", FilterName:="JPG"
                        .Parent.Delete
                    End With
                End If
            Next oObj
        Next wsSh
        ActiveWorkbook.Close 0
    Next li
    Set oObj = Nothing: Set wsSh = Nothing
    wsTmpSh.Delete
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    MsgBox "Объекты сохранены в папке: " & ThisWorkbook.Path, vbInformation, "www.excel-vba.ru"
End Sub
Также на форуме нашел функцию Как определить, есть ли рисунок в ячейке EXCEL, не не знаю как бы их связать вместе..
Visual Basic Скопировано
1
2
3
4
5
6
7
8
9
10
11
Public Function TestPictCell(Cell As Range) As Boolean
Dim TmpShape As Shape
 
TestPictCell = False
    
    For Each TmpShape In Cell.Worksheet.Shapes
        If TmpShape.Type = msoPicture Then  ' Это картинка?
            If Cell.Address = TmpShape.TopLeftCell.Address Then TestPictCell = True 'адреса равны?
        End If
    Next
End Function
Миниатюры
Как определить адрес ячейки, в которой находится картинка?  
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.07.2014, 20:58
Ответы с готовыми решениями:

Необходимо в Excel определить адрес ячейки, в которой нажали кнопку
Всех приветствую. Проблема в следующем: На листе Excel размещено около 2000 кнопок, допустим в столбце D. Необходимо, чтобы при...

Как получить адрес папки, в которой находится программа?
гуглил мало что нашел #include <windows.h> нужна прога 1) WIN32 С++ , как получить адрес папки, в которой...

Как получить адрес папки, в которой находится файл?
Всем добрый день. Можно ли в с++ (для линукс) как-то получить адрес директории, в которой лежит файл, если известен адрес файла. То есть,...

1
90 / 37 / 14
Регистрация: 03.11.2010
Сообщений: 429
21.07.2014, 16:13
sName = ActiveWorkbook.FullName & "_" & wsSh.Name & "_" & oObj.Name
вместо oObj.Name введите своё имя или полностью сформируйте имя файла sName
oObj.TopLeftCell.Address - адрес ячейки, где находиться TopLeft точка рисунка.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.07.2014, 16:13
Помогаю со студенческими работами здесь

Как узнать адрес страницы, на которой находится пользователь?
Привет! Собственно и весь вопрос... Использую JSP. И если такое возможно, хотелось бы узнать адрес страницы, с которой пришел пользователь....

Вопрос по адресации в Excel: как получить данные из ячейки, адрес которой указан в другой ячейке?
Доброго дня всем. Тут такое дело - в ячейке, к примеру А1 лежит номер столбца, а в ячейке А2 - номер строки. Как получить значение из...

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

Узнать адрес ячейки из которой была вызвана функция
Добрый день форумчане. я не спец в VBA. перед мной стала задача: узнать адрес ячейки из которой была вызвана функция и в ячейку рядом...

Как определить папку, в которой находится ехешник сервиса?
Как определить папку, в которой находится ехешник сервиса? При старте сервиса текущая директория устанавливается в %system32% :(


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
std::span в C++: Производительность и лучшие практики
NullReferenced 28.03.2025
std::span — одно из самых недооценённых нововведений стандарта C++20, которое радикально меняет подход к работе с непрерывными последовательностями данных. По сути, это невладеющее представление. . .
Многопоточность в C#: Threadpool
UnmanagedCoder 28.03.2025
Пул потоков в C# — это коллекция заранее созданных и готовых к использованию потоков, которые находятся в распоряжении приложения. Вместо того чтобы создавать и уничтожать потоки для каждой небольшой. . .
Вопросы на собеседованиях по микросервисам
ArchitectMsa 27.03.2025
Работодатели ищут не просто разработчиков, знающих базовые концепции, а специалистов, разбирающихся в тонкостях масштабирования, отказоустойчивости и производительности. Сейчас на первый план выходят. . .
Взаимодействие Python с REST API
py-thonny 27.03.2025
REST API - это архитектурный стиль взаимодействия компонентов распределённого приложения в сети. Python располагает функциональным набором инструментов для работы с REST API и основная библиотека для. . .
sshd restrictions, ssh access limitations
jigi33 26.03.2025
sshd restrictions | ssh access limitations рестрикции доступа на сервер sshd статья: https:/ / www. golinuxcloud. com/ restrict-allow-ssh-certain-users-groups-rhel
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточность в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru
Выделить код Копировать код Сохранить код Нормальный размер Увеличенный размер