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 des fonctions
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 {} ?>
Voici le lien de téléchargement du fichier XLS
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
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
Partager