Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHPExcel] Import danych z pliku
Forum PHP.pl > Forum > PHP
maniek74
Witam
W pliku Excel mam kolumnę 5,00 zł, przy imporcie otrzymuje $ 5.00. Jak można zrobić żeby otrzymać samo 5?
  1. <?php
  2. include '../class/PHPExcel/IOFactory.php';
  3. $inputFileName = '../Zeszyt1.xlsx';
  4. $objPHPExcel = PHPExcel_IOFactory::load($inputFileName);
  5. $allDataInSheet = $objPHPExcel->getActiveSheet()->toArray(null,true,true,true);
  6. $arrayCount = count($allDataInSheet);
  7. print '<table border="1">';
  8. for($i=3;$i<=$arrayCount;$i++){
  9. $collectName = $allDataInSheet[$i]["A"];
  10. $collectDateEnd = $allDataInSheet[$i]["B"];
  11. $collectLocation = $allDataInSheet[$i]["C"];
  12. $collectPrice = $allDataInSheet[$i]["D"];
  13. $collectEmail = $allDataInSheet[$i]["E"];
  14. $collectDate = $allDataInSheet[$i]["F"];
  15.  
  16. print '<tr>';
  17. print '<td>'.$collectName.'</td>';
  18. print '<td>'.$collectDateEnd.'</td>';
  19. print '<td>'.$collectLocation.'</td>';
  20. print '<td>'.$collectPrice.'</td>';
  21. print '<td>'.$collectEmail.'</td>';
  22. print '<td>'.$collectDate.'</td>';
  23. print '</tr>';
  24. }
  25. print '</table>';
  26. ?>


Pozdrawiam
CuteOne
  1. $collectPrice = (int) $allDataInSheet[$i]["D"]; //lub (float) w zależności od potrzeb
maniek74
Próbowalem zwraca 0 jeszcze zauważyłem problem z datą bo zamiast 2015-02-01 zwraca 02-01-15
CuteOne
Zrób dumpa z $allDataInSheet, i wrzuć nam tutaj. Problem z datmi, to ustawienia lokalne, w PL używamy dd-mm-YYYY, zrób z tego \DateTime a potem wyświetl format('YYYY-mm-dd') wink.gif
maniek74
z datą sobie już poradziłem:
$dateEnd = DateTime::createFromFormat('m-d-y', $allDataInSheet[$i]["B"]);
$date = DateTime::createFromFormat('m-d-y', $allDataInSheet[$i]["F"]);

i jest oki nie umiem jedynie sobie pordzić z ceną
próbowwałem
$number = filter_var($allDataInSheet[$i]["D"], FILTER_SANITIZE_NUMBER_INT);

ale zamiast 5 zwraca mi 500.

// Edit
Poradziłem sobie
$number = substr(filter_var($allDataInSheet[$i]["D"], FILTER_SANITIZE_NUMBER_INT), 0, -2);

Pytanie czynie ma lepszej metody aby zwrócił liczby w tej komórce.

Sorki że się spytam ale co to znaczy zrób dumpa z $allDataInSheet ?

Pozdrawiam
CuteOne
wstaw var_dump($allDataInSheet); przed pętlą
maniek74
zróciło ["D"]=> string(6) "$ 5.00", oczywiście jest tego więcej, ale nie chcę zaśmiecać forum
CuteOne
Ok już czaje o co chodzi wink.gif
https://degreedocumentation.wordpress.com/2...ll-in-phpexcel/
http://www.cmsws.com/examples/applications...mberFormat.html

W drugim linku masz również przykład zmiany daty
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.