Все сервисы Хабра
Сообщество IT-специалистов
Ответы на любые вопросы об IT
Профессиональное развитие в IT
Закрыть
Задать вопрос
rudejah
@rudejah
PHP
PhpSpreadsheet
Как заставить PHPExcell вернуть правильное поле?
Доброго утра, наверное.
После чтения файла с помощью PHPExcel столкнулся с проблемой, что банковский счет (20 цыфер) он преобразует в экспоненту (так как эксель любит только 15-ти циферные строчки)
Пытался и getFormattedValue, но как-то всё без успешно.
Может подскажете в какую сторону ковырять?
Вопрос задан
более трёх лет назад
3155 просмотров
Комментировать
Подписаться
2
Оценить
Комментировать
Facebook
Вконтакте
Twitter
Решения вопроса
0
Пригласить эксперта
Ответы на вопрос
3
rudejah
@rudejah
Автор вопроса
Поломав голову, посмотрев что выдает var_dump при разных конфигурациях.
Не нашел ничего лучше как в файле PHPExcel/Cell.php поменять немного кода:
Ищем public function setValueExplicit, в ней меняем
case PHPExcel_Cell_DataType::TYPE_NUMERIC:
$this->_value = (float)$pValue;
на
case PHPExcel_Cell_DataType::TYPE_NUMERIC:
$this->_value = (string)$pValue;
Но это только для моего случая и не является панацеей.
Ответ написан
более трёх лет назад
Комментировать
Нравится
1
Комментировать
Facebook
Вконтакте
Twitter
Дмитрий
@thewind
php программист, front / backend developer
getCalculatedValue не пробовали?
Ответ написан
более трёх лет назад
2
комментария
Нравится
2
комментария
Facebook
Вконтакте
Twitter
rudejah
@rudejah
Автор вопроса
и это тоже пробовал, результат один и тот же.
Написано
более трёх лет назад
Дмитрий
@thewind
rudejah
: у меня была похожая проблема - формат ячейки. В экселе есть ведущие нули, а phpexcel их убирает. Так и не решил, пошел другим путем.
Написано
более трёх лет назад
Kamaz541
@Kamaz541
можно сделать так:
$number = 0012;
$sheet->setCellValue("B1", $number);
$sheet->getStyle("B1")->getNumberFormat()->setFormatCode('0000');
Ответ написан
более трёх лет назад
Комментировать
Нравится
Комментировать
Facebook
Вконтакте
Twitter
Ваш ответ на вопрос
Войдите, чтобы написать ответ
Войти через центр авторизации
Похожие вопросы
PHP
Простой
Почему в PHP унитарная операция от плюса к минусу работает а обратно нет?
1 подписчик
18 часов назад
83 просмотра
1
ответ
PHP
Простой
Как скомбинировать массивы, чтобы получить все варианты сочетаний их элементов?
1 подписчик
23 сент.
209 просмотров
3
ответа
PHP
+1 ещё
Простой
Можно ли писать функции в текст?
1 подписчик
19 сент.
417 просмотров
2
ответа
PHP
Средний
Joomla 5 rest api — как создать материал с сохранением html элемента?
1 подписчик
18 сент.
97 просмотров
1
ответ
PHP
+1 ещё
Простой
Как в Битрикс с помощью PHP скрывать одну или несколько характеристик если они пустые?
1 подписчик
18 сент.
180 просмотров
2
ответа
PHP
Средний
Подключние к базе данных из класса — насколько правильно?
2 подписчика
14 сент.
361 просмотр
2
ответа
PHP
Простой
Почему не запускается session_start() на сервере от REG.RU?
1 подписчик
09 сент.
191 просмотр
3
ответа
JavaScript
+2 ещё
Простой
Не могу передать POST запрос ajax/js почему?
1 подписчик
07 сент.
634 просмотра
2
ответа
PHP
+2 ещё
Средний
Почему Joomla 5.3.3 обращается к /tmp?
1 подписчик
06 сент.
197 просмотров
1
ответ
PHP
+1 ещё
Простой
Требуется реальный пример как исправить ошибку с Warning: count(): Parameter must be an array or an object that implements Countable in ....?
1 подписчик
06 сент.
208 просмотров
2
ответа
Показать ещё
Загружается…
Вакансии с Хабр Карьеры
PHP разработчик
BGStaff
•
Москва
До 300 000 ₽
PHP разработчик
IT-hunter
До 6 500 $
Программист PHP/Laravel/Vue.js
What'sOnPic
До 200 000 ₽
Минуточку внимания
Войдите на сайт
Чтобы задать вопрос и получить на него квалифицированный ответ.
Войти через центр авторизации
Закрыть
Реклама