aboutsummaryrefslogtreecommitdiffstats
path: root/src/documentation/content/xdocs/trans/es/faq.xml
blob: 33076a51e4fe250c2c3bd6ded1a2b227591d6125 (plain)
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
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
<?xml version="1.0" encoding="ISO-8859-1"?>
<!--
   ====================================================================
   Licensed to the Apache Software Foundation (ASF) under one or more
   contributor license agreements.  See the NOTICE file distributed with
   this work for additional information regarding copyright ownership.
   The ASF licenses this file to You under the Apache License, Version 2.0
   (the "License"); you may not use this file except in compliance with
   the License.  You may obtain a copy of the License at

       http://www.apache.org/licenses/LICENSE-2.0

   Unless required by applicable law or agreed to in writing, software
   distributed under the License is distributed on an "AS IS" BASIS,
   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   See the License for the specific language governing permissions and
   limitations under the License.
   ====================================================================
-->
<!DOCTYPE faqs PUBLIC "-//APACHE//DTD FAQ V1.1//EN" "../../dtd/faq-v11.dtd">

<faqs title="Preguntas M Frecuentes (FAQ)">
    <faq>
        <question>
          or qula lectura de una hoja de cculo simple lleva tanto tiempo?
        </question>
        <answer>
          <p>
          Probablemente hayas habilitado el registro (logging). Dicho registro es
          una herramienta il para la bqueda de errores (debug). Tenerlo habilitado
          reducirel rendimiento en un factor de al menos 100. El registro es il para
          comprender por quPOI no puede leer alg fichero o para el propio desarrollo
          de POI.
          Los errores importantes se lanzan como excepciones, lo cual significa que
          probablemente no necesites el registro (log).
          </p>
        </answer>
    </faq>
    <faq>
        <question>
          ues el "eventmodel" (modelo de evento) de HSSF?
        </question>
        <answer>
              <p> El paquete "eventmodel" de HSSF es un nuevo API para la lectura m eficiente de ficheros
              XML. Requiere mayor conocimiento por parte del usuario, pero reduce el consumo de memoria a
              una dima parte. Estbasado en el modelo de eventos AWT en combinaci con SAX. Si necesita
              acceso de so-lectura a un fichero XML determinado, esta es la mejor manera de hacerlo.</p>
        </answer>

    </faq>
    <faq>
        <question>
          or quno puedo leer el documento que creutilizando Star Office 5.1?
        </question>
        <answer>
              <p>Star Office 5.1 escribe algunos registros utilizando el viejo estdar BIFF.
              Esto provoca algunos problemas con POI que so soporta BIFF8.</p>
        </answer>
    </faq>
    <faq>
        <question>
            or qurecibo una excepci cada vez que intento leer mi hoja de cculo?
        </question>
        <answer>
            <p>Es posible que su hoja de cculo contenga alguna caractertica que no est
            soportada actualmente por HSSF. Por ejemplo - hojas de cculo que contengan
            celdas con formato RTF (rich text) no est soportadas actualmente.</p>
        </answer>
    </faq>
    <faq>
        <question>
            oporta HSSF hojas de cculo protegidas?
        </question>
        <answer>
            <p>Al proteger una hoja de cculo, ta se cifra. No tocaremos el cifrado, porque no
            tenemos el suficiente conocimiento legal y no estamos seguros de las implicaciones que
            conllevar el intentar implementar esto. Si desea intentarlo, es libre de hacerlo y
            de adirlo como un mulo enchufable (plugin). Sin embargo, no lo guardaremos aqu</p>
        </answer>
    </faq>
    <faq>
        <question>
            o se sabe si un campo contiene una fecha con HSSF?
        </question>
        <answer>
            <p>Excel almacena las fechas como neros. Asla ica manera para determinar
            si una celda estrealmente almacenada como una fecha consiste en mirar su formato.
            Hay un modo de ayuda (helper) en HSSFDateUtil (desde la distribuci 1.7.0-dev)
            que lo comprueba. Gracias a Jason Hoffman por proporcionar la soluci.</p>
            <source>

case HSSFCell.CELL_TYPE_NUMERIC:
                  double d = cell.getNumericCellValue();
                  // test if a date!
                             if (HSSFDateUtil.isCellDateFormatted(cell)) {
                    // format in form of M/D/YY
                    cal.setTime(HSSFDateUtil.getJavaDate(d));
                    cellText =
                      (String.valueOf(cal.get(Calendar.YEAR))).substring(2);
                    cellText = cal.get(Calendar.MONTH)+1 + "/" +
                               cal.get(Calendar.DAY_OF_MONTH) + "/" +
                               cellText;
                  }

            </source>
        </answer>
    </faq>
    <faq>
        <question>
            Estoy intentando ver un fichero XLS enviado como flujo (stream) desde un servlet y tengo
            complicaciones. u es el problema?
        </question>
        <answer>
            <p>
            El problema normalmente se manifiesta como un mont de caracteres basura
            en la pantalla. El problema persiste incluso aunque hayas configurado el tipo mime
            correcto.
            </p>
            <p>
            La respuesta breve es: no dependas de IE para mostrar un fichero binario. 
            Escribe un documento adjunto como es debido si lo envs a trav de un servlet. 
            Toda versi de IE tiene diferentes fallos (bugs) en este sentido.
            </p>
            <p>
            El problema en la mayor de las versiones de IE reside en que no utiliza el tipo mime
            de la respuesta HTTP para determinar el tipo de fichero; en su lugar utiliza la extensi
            del fichero en la petici. Aspodr adir un <strong>.xls</strong> a su cadena de petici.
            Por ejemplo: <em>http://yourserver.com/myServelet.xls?param1=xx</em>. Esto se consigue
            filmente a trav del mapeo de URL en cualquier contenedor servlet. A veces una
            petici como
                <em>http://yourserver.com/myServelet?param1=xx&amp;dummy=file.xls</em> 
            tambi funciona.
            </p>
            <p>
            Para garantizar la correcta apertura del fichero en Excel desde IE, escribe
            tu fichero a un fichero temporal bajo su raiz web desde tu servlet. Env entonces
            una respuesta http al navegador para que haga una redirecci en el lado del cliente
            a tu fichero temporal. (Si haces una redirecci en el lado del servidor utilizando
            RequestDispatcher, tendr que adir .xls a la petici como se ha mendionado m
            arriba)
            </p>
            <p>
            Date cuenta de que cuando pides un documento que se abre con un manejador externo,
            IE a veces realiza dos peticiones al servidor web. Asque si tu proceso generador
            es pesado, tiene sentido escribir a un fichero temporal, para que peticiones
            mtiples utilicen el fichero estico.
            </p>
            <p>
            Nada de esto pertenece a Excel. El mismo problema ocurre cuando intentas general
            cualquier fichero binario dinicamente a un cliente IE. Por ejemplo, si generas
            ficheros pdf utilizando
                <link href="http://xml.apache.org/fop">FOP</link>,
                te encontrar con los mismos problemas.
            </p>
            <!-- Gracias a Avik por la respuesta -->
        </answer>
    </faq>
    <faq>
        <question>
            Quiero dar formato a una celda (Data format of a cell) de una hoja excel como
            ###,###,###.#### o ###,###,###.0000. s posible hacer esto con POI?
        </question>
        <answer>
            <p>
                HSSF no soporta todav formatos de datos personalizados, sin embargo,
                deber ser una facilidad razonablemente sencilla de adir y aceptaremos
                gustosos contribuciones en este ea.
            </p>
            <p>
                Estos son los formatos incluidos que soporta:
            </p>
            <p>
            <link href="http://jakarta.apache.org/poi/javadocs/javasrc/org/apache/poi/hssf/usermodel/HSSFDataFormat_java.html#HSSFDataFormat">http://jakarta.apache.org/poi/javadocs/javasrc/org/apache/poi/hssf/usermodel/HSSFDataFormat_java.html#HSSFDataFormat</link>
            </p>
        </answer>
    </faq>
    <faq>
        <question>
            o ado un borde alrededor de una celda unida (merged)?
        </question>
        <answer>
            <p>
            Ade celdas vacs alrededor de donde las celdas hubieran estado normalmente y
            configura los bordes individualmente para cada celda.
            Probablemente mejoraremos HSSF en el futuro para facilitar este proceso.
            </p>
        </answer>
    </faq>
    <faq>
        <question>
            Intentescribir valores en celdas ascomo cambiar el nombre de la hoja Excel
            en mi lengua nativa, pero no pude hacerlo. :(
        </question>
        <answer>
            <p>
            Por defecto HSSF utiliza valores de celdas y nombres de hoja en unicode comprimido,
            asi que para soportar la localizaci debers utilizar Unicode.
            Para hacerlo debers configurarlo manualmente:
            </p>
            <source>

                //
                // para el nombre de la hoja
                //
                HSSFWorkbook wb = new HSSFWorkbook();
                HSSFSheet s = wb.createSheet();
                wb.setSheetName( 0, "SomeUnicodeName", HSSFWorkbook.ENCODING_UTF_16 );


                //
                // para el valor de la celda
                //
                HSSFRow r = s.createRow( 0 );
                HSSFCell c = r.createCell( (short)0 );
                c.setCellType( HSSFCell.CELL_TYPE_STRING );
                c.setEncoding( HSSFCell.ENCODING_UTF_16 );
                c.setCellValue( "\u0422\u0435\u0441\u0442\u043E\u0432\u0430\u044F" );

            </source>
            <p>
            Asegate de que haces la llamada a setEncoding() antes de llamar a setCellValue(),
            si no, lo que le pases no serinterpretado correctamente.
            </p>
        </answer>
    </faq>
</faqs>