Bonjour, je viens vers vous car j'ai un problème d'indice qui ne débute pas à zero lorsque j'utilise PhpExcel

Je vous fourni le code

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
<?php 
session_start();
require_once 'PHPExcel.php';
require_once 'PHPExcel/Writer/Excel5.php';
require_once 'includes/identifiants.php';
require_once 'includes/fonction.php';
 
//error_reporting(E_ALL & ~E_NOTICE);
 
$connect=connect();
 
$sql = "select * from shp_export where document = '19' order by code_commu, nom";
$rs=pg_exec($connect,$sql);	
$k=0;
 
while ($val = pg_fetch_array($rs))
						{ 
 
							if($k%118 == 0)
							{
								$tableau[$k] = $val; //permet d'avoir l'enregistrement en double, pour pouvoir afficher le nom de la commune regroupant les Lieux dits
								$k++;
								$tableau[$k] = $val;
								$k++;
 
							}
							else
							if($val['code_commu'] != $comm)
							{
								$tableau[$k] = $val;
								$k++;
								$tableau[$k] = $val;
								$k++;
 
							}
							else
							{
								$tableau[$k] = $val;
								$k++;
							}
							$comm = $val['code_commu'];
						}
						$NbreData = $k;
 
 
$NbrLigne = 118;
if ($NbreData != 0) {
 
 
$workbook = new PHPExcel();
 
$sheet = $workbook->getActiveSheet();
 
//---------------------------------En tête----------------------------------------------/
$sheet->getPageSetup()->setPaperSize(PHPExcel_Worksheet_PageSetup::PAPERSIZE_A3); //format A3
 
$sheet->getPageSetup()->setOrientation(PHPExcel_Worksheet_PageSetup::ORIENTATION_PORTRAIT); //orientation Portrait
 
//--------------------Initialisation des tailles des colonnes------------------------------------//
$sheet->getColumnDimension('A')->setWidth(0.9595); 
$sheet->getColumnDimension('B')->setWidth(15.85);
$sheet->getColumnDimension('C')->setWidth(5.69);
$sheet->getColumnDimension('D')->setWidth(3.28);
$sheet->getColumnDimension('E')->setWidth(3.28);
$sheet->getColumnDimension('F')->setWidth(0.9595);
$sheet->getColumnDimension('G')->setWidth(15.85);
$sheet->getColumnDimension('H')->setWidth(5.69);
$sheet->getColumnDimension('I')->setWidth(3.28);
$sheet->getColumnDimension('J')->setWidth(3.28);
$sheet->getColumnDimension('K')->setWidth(0.9595);
$sheet->getColumnDimension('L')->setWidth(15.85);
$sheet->getColumnDimension('M')->setWidth(5.69);
$sheet->getColumnDimension('N')->setWidth(3.28);
$sheet->getColumnDimension('O')->setWidth(3.28);
$sheet->getColumnDimension('P')->setWidth(0.9595);
$sheet->getColumnDimension('Q')->setWidth(15.85);
$sheet->getColumnDimension('R')->setWidth(5.69);
$sheet->getColumnDimension('S')->setWidth(3.28);
$sheet->getColumnDimension('T')->setWidth(3.28);
$sheet->getColumnDimension('U')->setWidth(0.9595);
$sheet->getColumnDimension('V')->setWidth(15.85);
$sheet->getColumnDimension('W')->setWidth(5.69);
$sheet->getColumnDimension('X')->setWidth(3.28);
$sheet->getColumnDimension('Y')->setWidth(3.28);
$sheet->getColumnDimension('Z')->setWidth(0.9595);
 
//------------------------------Marge de la page----------------------------//
 
$sheet->getPageMargins()->setTop(0.20); //Valeur en inches
$sheet->getPageMargins()->setRight(0.156);
$sheet->getPageMargins()->setLeft(0.2535);
$sheet->getPageMargins()->setBottom(0.20);
 
$compteurPage = 1;
$ligneEntete = 0;
$colEntete = 0;
$i = 0;
for ($i=0; $i<$NbrLigne; $i++) {
 
 
 
 
		$j = 0;
 
 
while (($i+($j*$NbrLigne))%$NbrLigne==$i && ($i+($j*$NbrLigne))<$NbreData) 
		{
		$k = ($i+($j*$NbrLigne));
 
 
 
			$ligneExcel = lineExcel($i, $compteurPage);
			$colExcel = colExcel($j);
 
			$sheet->setCellValueByColumnAndRow($colExcel, $ligneExcel, $k);
 
 
			$j++;
			if($k%590 == 0 && $k>0)
			{
			$compteurPage++;
			}
 
		}
 
 
}
 
 
$writer = new PHPExcel_Writer_Excel5($workbook);
$records = './fichiertest.xls';
$writer->save($records);
unset($workbook);
 
ob_clean();
 
echo'<a href="./fichiertest.xls">Fichier Excel</a>';
 
}
 
 
 
else
{}
?>
code des fonctions

Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5
6
7
8
9
10
11
12
function lineExcel($vali, $Page)
{
$linex = ($vali+1) + (2 * $Page) + (118 * ($Page - 1));
return $linex;
}
 
function colExcel($valj)
{
$modulo = $valj%5;
$colex  = ($modulo + 1) + (5 * $modulo) - $modulo;
return $colex;
}//fin fonction
Voici le lien de téléchargement du fichier XLS

http://www.toofiles.com/fr/oip/docum...hiertest7.html

Merci

EDIT : Problème résolu, je n'ai pas utiliser de modulo dans le While. En gros j'ai changer toute la boucle