Модераторы: skyboy, MoLeX, Aliance, ksnk
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Баг при разборе значений строк из .csv файла, значения: 1 561,73 различаются кодом  
V
    Опции темы
Explicito
Дата 26.7.2007, 11:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 23
Регистрация: 26.12.2006

Репутация: нет
Всего: нет



Всем привет!
Так получается, что при разборе .csv файла, все данные перегоняю в массив, для удобства работы с ними,
значения поля хранятся в формате 1 132 425 638,56 они форматируются экселем, просто так нужно, для удобства работы с данными, всё же значения вида 1 132 425 638,56 читаются лучше чем 1132425638,56... когда я начинаю приобразовывать формат значений
из 1 132 425 638,56  =>  1132425638,56 делаю это так:
Код

foreach($this->data as $key => $value) {
      $value = str_replace(' ', '', $value);
      $value = str_replace(',', '.', $value);
      $yData[] = floatval($value); // из строки делаю float
}

В списке хранятся значения одного формата типа 1 132 425 638,56 ; 12 536 475 838,43...
одни значения функция str_replace(' ', '', $value) парсит правильно, а другие оставляет в исходном представлении, предполагаю что код символа пробела - разный в этих значениях, а когда преобразую во float, эти "проблемные" значения превращаются в 0 или возвращается первая часть значения до разделителя, в моём случае 1 или 12, даже и не думал что так может получиться..
потомучто при моих стандартных настройках Denver(a) всё работает исключительно, а когда заливаю на сервер хостмастера, вылазят
такие баги..

Ребят, может кто-то с этой проблемой уже сталкивался?
помогите пожалуйста

Это сообщение отредактировал(а) Explicito - 26.7.2007, 11:50
PM MAIL   Вверх
Flashdown
Дата 26.7.2007, 13:13 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 85
Регистрация: 27.5.2006
Где: Москва

Репутация: нет
Всего: нет



предполагаю что код символа пробела - разный в этих значениях
так проверь это smile 
PM MAIL ICQ   Вверх
Mal Hack
Дата 26.7.2007, 13:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Мудрый...
****


Профиль
Группа: Участник Клуба
Сообщений: 9926
Регистрация: 15.2.2004

Репутация: 122
Всего: 261



Я вот понять не могу, может я такой тупой, но ведь тут вам дано указание, совет, как лучше и правильно сделать?
Тут это тут: http://forum.vingrad.ru/index.php?showtopi...t&p=1206730
Неужели вы так и будете упираться и хранить данные как НЕ НАДО этого делать.
Формат вывода всегда можно изменить, добавить пробелы, точки и т.п.
PM ICQ   Вверх
Explicito
Дата 26.7.2007, 14:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 23
Регистрация: 26.12.2006

Репутация: нет
Всего: нет



если бы это зависило от меня, так бы и сделал, и не задавал бы этих вопросов, дело в том, что заказчик не хочет, чтобы формат значений был "компактным", говорит что ему не удобно, так можно наделать ошибок, значения плохо читаются..., этот человек заносит данные в файл, а моя программа парсит его и строит по этим данным графики, всё работает локально, но когда выкладываю на сервер хостмастера, начинает вредничать....нужно мне найти выход из положения...

Это сообщение отредактировал(а) Explicito - 26.7.2007, 14:22
PM MAIL   Вверх
Mal Hack
Дата 26.7.2007, 14:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Мудрый...
****


Профиль
Группа: Участник Клуба
Сообщений: 9926
Регистрация: 15.2.2004

Репутация: 122
Всего: 261



гребанные юзеры, итить их встек.

Как вы читаете данные из csv файла?
Попробуйте читать построчно и проходиться по строке sscanf. 
PM ICQ   Вверх
Explicito
Дата 26.7.2007, 15:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 23
Регистрация: 26.12.2006

Репутация: нет
Всего: нет



данные считываю так:

Код

$fileID = fopen($this->dataFilePath, "r");
while(($string = fgets($fileID, 1000)) !== false) {
      $fields = explode(";", trim($string));
      $timestamp = $this->getTimeStamp($fields[0]);
      for($i = 1; $i <= count($fields); $i ++) {
            $fieldValue = ($fields[$i - 1] == '')? $fieldValue = 'null' : $fields[$i - 1];
            $this->data[$timestamp][$i] = $fieldValue;
      }
}



PM MAIL   Вверх
Explicito
Дата 26.7.2007, 23:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 23
Регистрация: 26.12.2006

Репутация: нет
Всего: нет



Ура! Нашёл решение проблемы, опишу на всякий случай, может кому-то пригодится:
так как выражение:
Код

$value = preg_replace('/\s+/', '', $value); // заменить все пробелы на ''

не помогло, за то, ниже написанное, сработало удачно smile
Код

$value = preg_replace('/[^\d,]+/', '', $value); // заменить все символы кроме чисел и запятой на ''


Ребята, всем спасибо за советы и за помощь! 

PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "PHP"
Aliance
IZ@TOP
skyboy
SamDark
MoLeX

Новичкам:

  • PHP редакторы собираются и обсуждаются здесь
  • Электронные книги по PHP, документацию можно найти здесь
  • Интерпретатор PHP, полную документацию можно скачать на PHP.NET

Важно:

  • Не брезгуйте пользоваться тегами [code=php]КОД[/code] для повышения читабельности текста/кода.
  • Перед созданием новой темы воспользуйтесь поиском и загляните в FAQ
  • Действия модераторов можно обсудить здесь

Внимание:

  • Темы "ищу скрипт", "подскажите скрипт" и т.п. будут переноситься в форум "Web-технологии"
  • Темы с именами: "Срочно", "помогите", "не знаю как делать" будут УДАЛЯТЬСЯ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, IZ@TOP, skyboy, SamDark, MoLeX, awers.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0918 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.