powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Microsoft Office [игнор отключен] [закрыт для гостей] / VSTO 2010 Excel NumberFormat формат валют, копирование заранее заданных форматов валют
2 сообщений из 2, страница 1 из 1
VSTO 2010 Excel NumberFormat формат валют, копирование заранее заданных форматов валют
    #37454463
Фотография Santa_RND
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Здравствуйте, коллеги!

Задача простая:
Есть прайс-лист с различными листами (на каждом листе цены могут быть указаны в различных валютах; соответствующие ячейки содержат форматирование) необходимо написать кусок кода для копирования выбранных строк из различных листов прайс-листа и последующей вставки в новую книгу (подготовлен шаблон; формат ячеек, который будет отображать цену стоит по-умолчанию - "общий") с сохранением форматов чисел (цен) оригинального прайс-листа.

Псевдокод который не дает результатов:

Цикл по всем выбранным значениям прайс-листа
Worksheet_Шаблон.Cells(индекс строки, индекс столбца).NumberFormat = Worksheet_Прайс-лист.Cells(индекс строки, индекс столбца).NumberFormat;
Worksheet_Шаблон.Cells(индекс строки, индекс столбца).Value = Worksheet_Прайс-лист.Cells(индекс строки, индекс столбца).Value;

Не копируется формат!

Задача №2 - конвертация скопированных значений цены в различные валюты (обменный курс задается руками в ячейки). Нужно как-то определять в какой валюте скопированная цена.

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

Помогите, пожалуйста.
...
Рейтинг: 0 / 0
VSTO 2010 Excel NumberFormat формат валют, копирование заранее заданных форматов валют
    #37454873
EducatedFool
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Santa_RND, вы всё сильно усложняете.

Стандартный метод COPY, применяемый к объекту типа RANGE, копирует содержимое ячеек вместе с форматированием:

Всего делов-то:
Код: plaintext
Worksheet_Прайс-лист.Cells(индекс строки, индекс столбца).copy Worksheet_Шаблон.Cells(индекс строки, индекс столбца)
PS: Зачем по одной ячейке копировать, когда можно копировать строки или столбцы целиком? (как и диапазоны ячеек любого размера)


По вопросу 2: анализируете свойства NumberFormat и NumberFormatLocal
по ним определяете валюту.
...
Рейтинг: 0 / 0
2 сообщений из 2, страница 1 из 1
Форумы / Microsoft Office [игнор отключен] [закрыт для гостей] / VSTO 2010 Excel NumberFormat формат валют, копирование заранее заданных форматов валют
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]