AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 09.06.2007, 11:00   #1  
ymv2000 is offline
ymv2000
Участник
 
84 / 11 (0) +
Регистрация: 03.05.2006
Проблемы при экспорте в Excel
При экспорте данных в Excel происходит ненужное округление:
Пример
в Axapta 0,099 а в Excel попадает 0,100 ?

а вот другой пример:
в Axapta 0,99 а в Excel 0,99 -правильно!

как можно исправить это?

Формат ячейки в Excel использовал разный-не помогает.
Старый 09.06.2007, 12:09   #2  
MikeR is offline
MikeR
MCT
Аватар для MikeR
MCBMSS
Лучший по профессии 2015
Лучший по профессии 2014
 
1,628 / 627 (24) +++++++
Регистрация: 28.11.2005
Адрес: просто землянин
static void Job23333333(Args _args)
{
AsciiIo dataFile = new AsciiIo('c:\\_1.xls', "w");
real test = 0.099;
;
dataFile.outFieldDelimiter("\t");
dataFile.write([
num2str(test,2,3,2,2),
strfmt('%1',test)]);
WinAPI::shellExecute('c:\\_1.xls');
}
Старый 09.06.2007, 14:10   #3  
Владимир Максимов is offline
Владимир Максимов
Участник
КОРУС Консалтинг
 
1,691 / 1195 (43) ++++++++
Регистрация: 13.01.2004
Записей в блоге: 3
А каким способом экспортируете данные? Может, Excel тут вообще не при чем, а виноват способ передачи данных?

Например, использование strFmt("%1",0.099) автоматически проведет округление, поскольку использует текущие региональные настройки системы.
Старый 09.06.2007, 15:33   #4  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Цитата:
Сообщение от Владимир Максимов Посмотреть сообщение
А каким способом экспортируете данные? Может, Excel тут вообще не при чем, а виноват способ передачи данных?
Например, использование strFmt("%1",0.099) автоматически проведет округление, поскольку использует текущие региональные настройки системы.
Кстати, да, тоже сталкивался с таким «эффектом» использования strfmt(), когда надо было выводить лог изменений в полях таблицы при импорте данных. Для strfmt() можно использовать примерно такой код (пример переделан из класса обновления InventTable, но легко можно сделать поддержку произвольных таблиц):
X++:
class smth
{
    // map <InventTable fieldId> -> [<fieldName>, <baseType>, <noOfDecimals>]
    Map mapFieldData;  
}
void printField(InventTable _inv, FieldId _fieldId)
{
    DictField           dictField;
    SysDictType         dictType;
    Types               baseType;
    int                 nDecimals;
    str                 strFldName;
    str                 strValue;
    ;
    // cache field information
    if(!mapFieldData) mapFieldData = new Map(Types::Integer, Types::Container);
    if(!mapFieldData.exists(_fieldId))
    {
        dictField   = new DictField(_inv.tableId, _fieldId);
        dictType    = new SysDictType(dictField.typeId());
        strFldName  = dictField.name();
        baseType    = dictField.baseType();
        nDecimals   = dictType.noOfDecimals();
        mapFieldData.insert(_fieldId, [strFldName, baseType, nDecimals]);
    } else
        [strFldName, baseType, nDecimals] = mapFieldData.lookup(_fieldId);
    switch(baseType)
    {
        // print as many decimals as it's set up in the EDT
        case Types::Real:   strValue = num2str(_inv.(_fieldId),1,nDecimals,1,0);
                            break;
        default         :   strValue = strfmt('%1',_inv.(_fieldId));
    }
    info(strfmt(@"For item '%1 - %2' %3 value: %5%4%5",
                inv.ItemId, inv.itemName(), strFldName, strValue,
                (baseType == Types::String ? @"'" : '')));
}
Старый 13.06.2007, 06:51   #5  
ymv2000 is offline
ymv2000
Участник
 
84 / 11 (0) +
Регистрация: 03.05.2006
Спасибо
действительно дело было в формате передачи данных из Axapta!
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Скорость работы при экспорте в Excel YVAS DAX: Программирование 17 06.04.2010 14:25
Проблемы с выгрузкой отчета их HTML в Excel. Ax3.0 Бриллиантик DAX: Функционал 20 31.03.2008 12:05
Автовысота строк при экспорте в excel andy239 DAX: Программирование 17 08.11.2005 16:51
проблемы с Excel Акавешка DAX: Программирование 6 27.10.2005 12:10
Ошибки при экспорте в Excel Владимир Максимов DAX: Программирование 9 06.08.2004 10:12

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 19:07.