• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Undefined offset: 0 PHP

Object Storage Arubacloud
0 głosów
645 wizyt
pytanie zadane 16 września 2018 w PHP przez hiper007 Stary wyjadacz (11,270 p.)
zamknięte 17 września 2018 przez hiper007

Witam!

Próbuję eksportować danee z tabeli do pliku Excel ;)

	mysqli_report(MYSQLI_REPORT_STRICT);
		
	try 
	{
		$polaczenie = new mysqli($host, $db_login, $db_pass, $db_name);
		
		if ($polaczenie->connect_errno!=0)
		{
			throw new Exception(mysqli_connect_errno());
		}
		else
		{

 
 
 $login=$_SESSION['login'];
 
$rezultat = $polaczenie->query("SHOW COLUMNS FROM ".$table." WHERE `Field` != 'color' AND `Field` != 'color2' AND `Field` != 'id'");
$i = 0;
if ($rezultat->num_rows > 0) {
while ($wiersz = $rezultat->fetch_assoc()) {
$csv_output.= $wiersz['Field']."\t";
$i++;
}
$csv_output .= "\n";
}
$rezultat2 = $polaczenie->query("SELECT appt.awizacja, appt.data_awizacja, appt.godz_awiz, appt.godz_pod, appt.zamowienie, appt.nazwa, appt.kanal, appt.spedycja, appt.linii, appt.palety, appt.kartony, appt.rampa, appt.rampa_typ, appt.komentarz, appt.artykul, appt.il_zamowien, appt.nr_naczepy ,appt.tel_kierowcy, appt.status, appt.kod FROM ".$table.", ".$table2." WHERE  appt.data_awizacja=data_aw.aw_data AND data_aw.login='$login' ORDER BY  appt.kod, appt.godz_awiz, appt.awizacja DESC");
while ($wiersz2 = $rezultat2->fetch_assoc()) {
for ($j=0;$j<$i;$j++) {
$csv_output.= $wiersz2[$j]."\t";

}
 $csv_output.= "\t";
 $csv_output .= "\n";
}
 
 		$csv_output = "\xFF\xFE" .mb_convert_encoding($csv_output, 'UTF-16LE', 'UTF-8');
		$filename = "Awizacje ".date("Y-m-d_H-i-s").".xls";

		header('Content-type: application/vnd.ms-excel;charset=UTF-8');
		header('Content-Disposition: attachment; filename='.$filename);
		header("Cache-Control: no-cache");

print $csv_output;
exit;

		
		}
	}
	catch(Exception $e)
	{
		echo '<span style="color:red;">Błąd serwera! Przepraszamy za niedogodności i prosimy o wizytę w innym terminie!</span>';
		echo '<br />Informacja developerska: '.$e;
	}

?> 

Problemw tym,że podczas próby eksportu wyskakuje błąd:

 Undefined offset: 0

Undefined offset: 1

Undefined offset: 2

......

W czym może być błąd?? Gdzie leży problem...

Z góry dzięki ;) Próbowałem już rózne sposoby i nie mam pomysłu...

komentarz zamknięcia: Problem rozwiązany

1 odpowiedź

+1 głos
odpowiedź 16 września 2018 przez Arkadiusz Waluk Ekspert (287,950 p.)
wybrane 17 września 2018 przez hiper007
 
Najlepsza

Zapewne chodzi o

$csv_output.= $wiersz2[$j]."\t";

bo tylko tutaj widzę odwoływanie się do liczbowego elementu tablicy, a nie podałeś o jaką linię chodzi. A tablica $wiersz2 zapewne nie ma elementów z podanymi kluczami, bo uzyskujesz ją z fetch_assoc(), a funkcja ta jak sama nazwa mówi, zwraca tablicę asocjacyjną - czyli kluczami są nazwy kolumn. Jak chcesz dostać klucze jako kolejne cyfry użyj fetch_array(). Ewentualnie przerób odpowiednio wcześniejszy kod, nie do końca wiem jaki ma być finalny efekt i czy nie jest to przekombinowane.

PS strasznie nieczytelnie się czyta ten kod ze względu na formatowanie/wcięcia. Nazewnictwo zmiennych typu $i i $j też nie ułatwia, pomijając już że raz nazywasz zmienne po polsku a raz po angielsku.

komentarz 17 września 2018 przez hiper007 Stary wyjadacz (11,270 p.)
$link = mysql_connect($host, $user, $pass) or die("Can not connect." . mysql_error());
mysql_select_db($db) or die("Can not connect.");

$kodowanie=mysql_query('SET NAMES \'utf8\'');
$login=$_SESSION['login'];
 
$result = mysql_query("SHOW COLUMNS FROM ".$table." WHERE `Field` != 'color' AND `Field` != 'color2' AND `Field` != 'id'");
$i = 0;
if (mysql_num_rows($result) > 0) {
while ($row = mysql_fetch_assoc($result)) {
$csv_output.= $row['Field']."\t";
$i++;
}
$csv_output .= "\n";
}
$values = mysql_query("SELECT appt.awizacja, appt.data_awizacja, appt.godz_awiz, appt.godz_pod, appt.zamowienie, appt.nazwa, appt.kanal, appt.spedycja, appt.linii, appt.palety, appt.kartony, appt.rampa, appt.rampa_typ, appt.komentarz, appt.artykul, appt.il_zamowien, appt.nr_naczepy ,appt.tel_kierowcy, appt.status, appt.kod FROM ".$table.", ".$table2." WHERE  appt.data_awizacja=data_aw.aw_data AND data_aw.login='$login' ORDER BY  appt.kod, appt.godz_awiz, appt.awizacja DESC");
while ($rowr = mysql_fetch_row($values)) {
for ($j=0;$j<$i;$j++) {
$csv_output.= $rowr[$j]."\t";

}
 $csv_output.= "\t";
 $csv_output .= "\n";
}
 
 		$csv_output = "\xFF\xFE" .mb_convert_encoding($csv_output, 'UTF-16LE', 'UTF-8');
		$filename = "Awizacje ".date("Y-m-d_H-i-s").".xls";

		header('Content-type: application/vnd.ms-excel;charset=UTF-8');
		header('Content-Disposition: attachment; filename='.$filename);
		header("Cache-Control: no-cache");

print $csv_output;
exit;

Ale np. ten sam kod tylko w postaci starej łącząc się z bazą mysql_connect działa poprawnie, ale po przerobioniu go na mysqli już nie eksportuje ;) hmmm

Gdzie może być problem

komentarz 17 września 2018 przez Arkadiusz Waluk Ekspert (287,950 p.)

Przecież dokładnie opisałem Ci problem i podałem rozwiązania:

tablica $wiersz2 zapewne nie ma elementów z podanymi kluczami, bo uzyskujesz ją z fetch_assoc(), a funkcja ta jak sama nazwa mówi, zwraca tablicę asocjacyjną - czyli kluczami są nazwy kolumn. Jak chcesz dostać klucze jako kolejne cyfry użyj fetch_array(). Ewentualnie przerób odpowiednio wcześniejszy kod

Poprzedni kod działa bo zwracasz tablicę z elementami z kluczami numerycznymi - wykorzystałeś mysql_fetch_row(): http://php.net/manual/en/function.mysql-fetch-row.php I w sumie gdybyś w nowym kodzie użył fetch_row() a nie podanego powyżej przeze mnie fetch_array() to też by wystarczyło. fetch_array() umożliwia dodatkowo ustawienie czego jako klucze oczekujesz, domyślnie są obydwa (cyferka i nazwa kolumny).

Podobne pytania

0 głosów
1 odpowiedź 855 wizyt
pytanie zadane 15 lipca 2019 w PHP przez niezalogowany
0 głosów
2 odpowiedzi 256 wizyt
pytanie zadane 3 lipca 2018 w PHP przez Wyshak Początkujący (260 p.)
0 głosów
1 odpowiedź 564 wizyt
pytanie zadane 28 grudnia 2017 w PHP przez kingkushlee Gaduła (3,960 p.)

92,554 zapytań

141,399 odpowiedzi

319,535 komentarzy

61,938 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...