jueves, 29 de mayo de 2014

SQLSERVER Conocer cuanto espacio ocupa una Base de datos

Ejecutando el siguiente comando sobre el monitor de comandos obtendremos la información de espacio de nuestra Base de datos

EXEC sp_spaceused N'NOMBRE_DE_LA_TABLA';

Obtendremos por pantalla el resultado como el de la imagen..
El valor viene expresado en KB para conocer el espacio que ocupa en MB Basta con divivir la cantidad indicada en el registro data entre 1024 de modo que en este ejemplo nuestra tabla de lineastickets ocupa unos 258 MB aproximadamente

viernes, 23 de mayo de 2014

Sumar o restar dias, años o meses a una fecha en TSQL con SQLSERVER

Tenemos almacenada en una tabla una columna fecha que consultaremos con una sentencia simple

select fecha from tabla

pero queremos calcular a partir de esta fecha .. 90 dias despues que fecha sería ...
pues para ello usaremos la funcion:

DATEADD (datepart , number , date )

Esta función tiene 3 parámetros:
- el primero "datepart" dice a que "parte de la fecha" (dias, meses o años) sumaremos/restaremos la cantidad que queremos añadir o sustraer a la fecha.

- el segundo "number" representa la cantidad que sumaremos o restaremos "10" dias, "10" mese, "10" años.. OJOO (menos 10, "-10" también puede ponerse)

- el ultimo es la fecha de partida

la sintaxis quedaría así...

select  fecha, dateADd(DD, 10, FECHA) FechaControl from tabla

en este ejemplo hemos devuelto la fecha de la tabla y la fecha 10 días despues

Para desginar el primer parametro hay que utilizar la siguiente tabla:

datepart
Abbreviations
year
yy , yyyy
quarter
qq , q
month
mm , m
dayofyear
dy , y
day
dd , d
week
wk , ww
weekday
dw , w
hour
hh
minute
mi , n
second
ss , s
millisecond
ms
microsecond
mcs
nanosecond
ns


fuente: http://msdn.microsoft.com/en-us/library/ms186819.aspx

miércoles, 21 de mayo de 2014

Etiquetar el eje X de un Chat en ASP C#

Esta es la sintaxis:
Chart1.Series["Default"].Points[0].AxisLabel = "First Point";
Chart1.Series["Default"].Points[1].AxisLabel = "Second Point";


Esto es un copiado de la información proporcionada por Microsoft. Creo que es muy facil de comprender y completa por eso he realizado simplemente un volcado del contenido.

Fuente: http://msdn.microsoft.com/es-es/library/dd456628.aspx

Etiquetas

Visual Studio 2013
Personas que lo han encontrado útil: 1 de 1 Valorar este tema
En el control Chart, puede utilizar etiquetas para los ejes y etiquetas para los puntos de datos con el fin de hacer sus gráficos más informativos.

Utilizar etiquetas para los ejes

El control Chart etiqueta los ejes del área del gráfico de tres maneras diferentes, en orden de prioridad ascendente:
  • Etiquetar los ejes numéricamente
  • Etiquetar los ejes mediante texto
  • Etiquetar los ejes mediante etiquetas personalizadas
Estos métodos difieren principalmente en cómo se genera el texto de las etiquetas. Puede utilizar un método diferente para cada uno de los ejes. Por ejemplo, utilizar un conjunto de etiquetas personalizadas para el eje Y y etiquetas de texto para el eje X.

Dd456628.collapse_all(es-es,VS.120).gifEtiquetar los ejes numéricamente

Si un eje no contiene etiquetas personalizadas, y los datos trazados no tienen etiquetas de eje, el control Chart muestra automáticamente las etiquetas de eje en un intervalo especificado por la propiedad Axis.Interval. Para obtener más información sobre la propiedad, vea Eje

Dd456628.collapse_all(es-es,VS.120).gifEtiquetar los ejes mediante texto

Puede etiquetar el eje según el conjunto de datos particular utilizado mediante la propiedad DataPoint.AxisLabel. Una vez establecida esta propiedad con una cadena de etiqueta, el gráfico muestra la cadena de la etiqueta en el eje en la posición del punto de datos.
Nota Nota
Cuando el control Chart contiene un gran conjunto de datos, puede mostrar selectivamente las etiquetas de eje. Para asegurarse de que todas las etiquetas de eje están visibles, establezca la propiedad Axis.Interval en 1.
El siguiente ejemplo de código establece dos etiquetas en el eje para los dos puntos de datos.
Chart1.Series["Default"].Points[0].AxisLabel = "First Point";
Chart1.Series["Default"].Points[1].AxisLabel = "Second Point";

Dd456628.collapse_all(es-es,VS.120).gifEtiquetar los ejes mediante etiquetas personalizadas

Utilice las etiquetas personalizadas para proporcionar texto personalizado para los ejes. Las etiquetas personalizadas se implementan utilizando la propiedad de colecciónCustomLabels. Si utiliza etiquetas personalizadas, el área del gráfico no muestra etiquetas de eje en los puntos de datos.
Al utilizar objetos CustomLabel, deberá establecer las propiedades FromPosition y ToPosition de cada objeto CustomLabel, y estas propiedades deben especificar el ancho del área de texto de la etiqueta. No asigne el mismo valor a ambas propiedades, ya que representan un intervalo. Para colocar una etiqueta personalizada directamente bajo un punto de datos y su marca de graduación asociada, establezca la propiedad FromPosition en el valor del eje de ese punto de datos menos la mitad del intervalo de la marca de graduación y establezca la propiedad ToPosition en el valor del eje de ese punto de datos más la mitad del intervalo de la marca de graduación. Por ejemplo, si un eje tiene un intervalo de 1 (1, 2, 3…), y desea usar una etiqueta personalizada en X=2, entonces establezca las propiedades FromPosition y ToPosition en 1,5 y 2,5, respectivamente.
La propiedad RowIndex especifica en qué fila se mostrará la etiqueta personalizada. Si se utiliza una etiqueta personalizada en la primera fila de etiquetas, el área del gráfico no mostrará ninguna etiqueta de la escala del eje. Las únicas etiquetas permitidas en la segunda fila y siguientes serán las etiquetas personalizadas.

Dd456628.collapse_all(es-es,VS.120).gifFormatos y estilos de etiqueta de los ejes

Puede establecer los estilos de etiqueta de un eje mediante la propiedad LabelStyle del objeto Axis. Las propiedades de estilo de etiqueta que establezca en esta propiedad, comoLabelStyle.Font, se aplican a las etiquetas de un eje. Si las etiquetas del eje están demasiado cerca unas de otras, puede establecer propiedad LabelStyle.LabelsAutoFit oLabelStyle.Offset en True.
Al etiquetar los ejes numéricamente, también puede dar formato a los números utilizando la propiedad LabelStyle.Format.
El siguiente código muestra cómo establecer el eje Y principal con formato de divisa.
Chart1.ChartAreas["Default"].AxisY.LabelStyle.Format = "C";
El siguiente código muestra el día de semana en el eje X principal.Para obtener más información sobre cómo mostrar valores de fecha y hora como etiquetas de eje, vea Trabajar con valores de fecha y hora.
Chart1.ChartAreas["Default"].AxisX.LabelStyle.Format = "dddd";

Etiquetar puntos de datos

Puede mostrar etiquetas en los puntos de datos en el área de trazado. Para mostrar los valores de los puntos de datos como etiquetas, utilice la propiedad IsValueShownAsLabel en el objeto DataPoint o Series. Para mostrar otro texto como etiquetas de los puntos de datos, utilice la propiedad Series.Label.
Para utilizar datos en las etiquetas, utilice palabras clave en la propiedad Series.Label. En tiempo de ejecución, el gráfico reemplaza la palabra clave con los valores adecuados. Por ejemplo, el siguiente código muestra una etiqueta multilínea para cada punto de datos, con el valor Y en la primera línea y el valor X en la segunda línea.
Chart1.Series["Series1"].Label = "Y = #VALY\nX = #VALX";
Para obtener más información, vea Palabras clave.

Dd456628.collapse_all(es-es,VS.120).gifUtilizar etiquetas inteligentes

Dependiendo del tipo de gráfico, puede utilizar la propiedad Series.SmartLabelStyle para establecer etiquetas para puntos de datos que no entran en colisión.Esto resulta útil cuando se agrupan puntos de datos.
NotaNota
La propiedad Series.SmartLabelStyle no tiene ningún efecto sobre los tipos de gráficos de barrasbarras de intervalocircularanilloscolumnas de intervaloáreas apiladasáreas 100% apiladasbarras apiladasbarras 100% apiladas.
Para habilitar las etiquetas inteligentes, utilice el siguiente código.
Chart1.Series["Series1"].SmartLabelStyle.Enabled = true;
A continuación, puede utilizar propiedades de SmartLabelStyle tales como CalloutStyle y CalloutLineColor para controlar la apariencia de las etiquetas inteligentes.


martes, 20 de mayo de 2014

Separar una cadena en función de un delimitador Delphi

program Project28;

{$APPTYPE CONSOLE}

uses
  Classes,
  SysUtils;

procedure Split(Delimiter: Char; Str: string; ListOfStrings: TStrings) ;
begin
   ListOfStrings.Clear;
   ListOfStrings.Delimiter     := Delimiter;
   ListOfStrings.DelimitedText := Str;
end;


var
   OutPutList: TStringList;
begin
   OutPutList := TStringList.Create;
   try
     Split(':', 'word:doc,txt,docx', OutPutList) ;
     Writeln(OutPutList.Text);
     Readln;
   finally
     OutPutList.Free;
   end;
end.
Fuente: http://stackoverflow.com/questions/2625707/split-a-string-into-an-array-of-strings-based-on-a-delimiter

lunes, 19 de mayo de 2014

Mensajes de error en ficheros JPG

0  cstrJMSG_NOMESSAGE               'Bogus message code %d'; (* Must be first entry! *)
  1  cstrJERR_ARITH_NOTIMPL           'Sorry, there are legal restrictions on arithmetic coding'
  2  cstrJERR_BAD_ALIGN_TYPE          'ALIGN_TYPE is wrong, please fix'
  3  cstrJERR_BAD_ALLOC_CHUNK         'MAX_ALLOC_CHUNK is wrong, please fix'
  4  cstrJERR_BAD_BUFFER_MODE         'Bogus buffer control mode'
  5  cstrJERR_BAD_COMPONENT_ID        'Invalid component ID %d in SOS'
  6  cstrJERR_BAD_DCTSIZE             'IDCT output block size %d not supported'
  7  cstrJERR_BAD_IN_COLORSPACE       'Bogus input colorspace'
  8  cstrJERR_BAD_J_COLORSPACE        'Bogus JPEG colorspace'
  9  cstrJERR_BAD_LENGTH              'Bogus marker length'
 10  cstrJERR_BAD_LIB_VERSION         'Wrong JPEG library version: library is %d, caller expects %d'
 11  cstrJERR_BAD_MCU_SIZE            'Sampling factors too large for interleaved scan'
 12  cstrJERR_BAD_POOL_ID             'Invalid memory pool code %d'
 13  cstrJERR_BAD_PRECISION           'Unsupported JPEG data precision %d'
 14  cstrJERR_BAD_PROGRESSION         'Invalid progressive parameters Ss=%d Se=%d Ah=%d Al=%d'
 15  cstrJERR_BAD_PROG_SCRIPT         'Invalid progressive parameters at scan script entry %d'
 16  cstrJERR_BAD_SAMPLING            'Bogus sampling factors'
 17  cstrJERR_BAD_SCAN_SCRIPT         'Invalid scan script at entry %d'
 18  cstrJERR_BAD_STATE               'Improper call to JPEG library in state %d'
 19  cstrJERR_BAD_STRUCT_SIZE         'JPEG parameter struct mismatch: library thinks size is %u, caller expects %u'
 20  cstrJERR_BAD_VIRTUAL_ACCESS      'Bogus virtual array access'
 21  cstrJERR_BUFFER_SIZE             'Buffer passed to JPEG library is too small'
 22  cstrJERR_CANT_SUSPEND            'Suspension not allowed here'
 23  cstrJERR_CCIR601_NOTIMPL         'CCIR601 sampling not implemented yet'
 24  cstrJERR_COMPONENT_COUNT         'Too many color components: %d, max %d'
 25  cstrJERR_CONVERSION_NOTIMPL      'Unsupported color conversion request'
 26  cstrJERR_DAC_INDEX               'Bogus DAC index %d'
 27  cstrJERR_DAC_VALUE               'Bogus DAC value 0x%x'
 28  cstrJERR_DHT_COUNTS              'Bogus DHT counts'
 29  cstrJERR_DHT_INDEX               'Bogus DHT index %d'
 30  cstrJERR_DQT_INDEX               'Bogus DQT index %d'
 31  cstrJERR_EMPTY_IMAGE             'Empty JPEG image (DNL not supported)'
 32  cstrJERR_EMS_READ                'Read from EMS failed'
 33  cstrJERR_EMS_WRITE               'Write to EMS failed'
 34  cstrJERR_EOI_EXPECTED            'Didn''t expect more than one scan'
 35  cstrJERR_FILE_READ               'Input file read error'
 36  cstrJERR_FILE_WRITE              'Output file write error --- out of disk space?'
 37  cstrJERR_FRACT_SAMPLE_NOTIMPL    'Fractional sampling not implemented yet'
 38  cstrJERR_HUFF_CLEN_OVERFLOW      'Huffman code size table overflow'
 39  cstrJERR_HUFF_MISSING_CODE       'Missing Huffman code table entry'
 40  cstrJERR_IMAGE_TOO_BIG           'Maximum supported image dimension is %u pixels'
 41  cstrJERR_INPUT_EMPTY             'Empty input file'
 42  cstrJERR_INPUT_EOF               'Premature end of input file'
 43  cstrJERR_MISMATCHED_QUANT_TABLE  'Cannot transcode due to multiple use of quantization table %d'
 44  cstrJERR_MISSING_DATA            'Scan script does not transmit all data'
 45  cstrJERR_MODE_CHANGE             'Invalid color quantization mode change'
 46  cstrJERR_NOTIMPL                 'Not implemented yet'
 47  cstrJERR_NOT_COMPILED            'Requested feature was omitted at compile time'
 48  cstrJERR_NO_BACKING_STORE        'Backing store not supported'
 49  cstrJERR_NO_HUFF_TABLE           'Huffman table 0x%02x was not defined'
 50  cstrJERR_NO_IMAGE                'JPEG datastream contains no image'
 51  cstrJERR_NO_QUANT_TABLE          'Quantization table 0x%02x was not defined'
 52  cstrJERR_NO_SOI                  'Not a JPEG file: starts with 0x%02x 0x%02x'
 53  cstrJERR_OUT_OF_MEMORY           'Insufficient memory (case %d)'
 54  cstrJERR_QUANT_COMPONENTS        'Cannot quantize more than %d color components'
 55  cstrJERR_QUANT_FEW_COLORS        'Cannot quantize to fewer than %d colors'
 56  cstrJERR_QUANT_MANY_COLORS       'Cannot quantize to more than %d colors'
 57  cstrJERR_SOF_DUPLICATE           'Invalid JPEG file structure: two SOF markers'
 58  cstrJERR_SOF_NO_SOS              'Invalid JPEG file structure: missing SOS marker'
 59  cstrJERR_SOF_UNSUPPORTED         'Unsupported JPEG process: SOF type 0x%02x'
 60  cstrJERR_SOI_DUPLICATE           'Invalid JPEG file structure: two SOI markers'
 61  cstrJERR_SOS_NO_SOF              'Invalid JPEG file structure: SOS before SOF'
 62  cstrJERR_TFILE_CREATE            'Failed to create temporary file %s'
 63  cstrJERR_TFILE_READ              'Read failed on temporary file'
 64  cstrJERR_TFILE_SEEK              'Seek failed on temporary file'
 65  cstrJERR_TFILE_WRITE             'Write failed on temporary file --- out of disk space?'
 66  cstrJERR_TOO_LITTLE_DATA         'Application transferred too few scanlines'
 67  cstrJERR_UNKNOWN_MARKER          'Unsupported marker type 0x%02x'
 68  cstrJERR_VIRTUAL_BUG             'Virtual array controller messed up'
 69  cstrJERR_WIDTH_OVERFLOW          'Image too wide for this implementation'
 70  cstrJERR_XMS_READ                'Read from XMS failed'
 71  cstrJERR_XMS_WRITE               'Write to XMS failed'
 72  cstrJMSG_COPYRIGHT               cstrJCOPYRIGHT
 73  cstrJMSG_VERSION                 cstrJVERSION
 74  cstrJTRC_16BIT_TABLES            'Caution: quantization tables are too coarse for baseline JPEG'
 75  cstrJTRC_ADOBE                   'Adobe APP14 marker: version %d, flags 0x%04x 0x%04x, transform %d'
 76  cstrJTRC_APP0                    'Unknown APP0 marker (not JFIF), length %u'
 77  cstrJTRC_APP14                   'Unknown APP14 marker (not Adobe), length %u'
 78  cstrJTRC_DAC                     'Define Arithmetic Table 0x%02x: 0x%02x'
 79  cstrJTRC_DHT                     'Define Huffman Table 0x%02x'
 80  cstrJTRC_DQT                     'Define Quantization Table %d  precision %d'
 81  cstrJTRC_DRI                     'Define Restart Interval %u'
 82  cstrJTRC_EMS_CLOSE               'Freed EMS handle %u'
 83  cstrJTRC_EMS_OPEN                'Obtained EMS handle %u'
 84  cstrJTRC_EOI                     'End Of Image'
 85  cstrJTRC_HUFFBITS                '        %3d %3d %3d %3d %3d %3d %3d %3d'
 86  cstrJTRC_JFIF                    'JFIF APP0 marker, density %dx%d  %d'
 87  cstrJTRC_JFIF_BADTHUMBNAILSIZE   'Warning: thumbnail image size does not match data length %u'
 88  cstrJTRC_JFIF_MINOR              'Unknown JFIF minor revision number %d.%02d'
 89  cstrJTRC_JFIF_THUMBNAIL          '    with %d x %d thumbnail image'
 90  cstrJTRC_MISC_MARKER             'Skipping marker 0x%02x, length %u'
 91  cstrJTRC_PARMLESS_MARKER         'Unexpected marker 0x%02x'
 92  cstrJTRC_QUANTVALS               '        %4u %4u %4u %4u %4u %4u %4u %4u'
 93  cstrJTRC_QUANT_3_NCOLORS         'Quantizing to %d = %d*%d*%d colors'
 94  cstrJTRC_QUANT_NCOLORS           'Quantizing to %d colors'
 95  cstrJTRC_QUANT_SELECTED          'Selected %d colors for quantization'
 96  cstrJTRC_RECOVERY_ACTION         'At marker 0x%02x, recovery action %d'
 97  cstrJTRC_RST                     'RST%d'
 98  cstrJTRC_SMOOTH_NOTIMPL          'Smoothing not supported with nonstandard sampling ratios'
 99  cstrJTRC_SOF                     'Start Of Frame 0x%02x: width=%u, height=%u, components=%d'
100  cstrJTRC_SOF_COMPONENT           '    Component %d: %dhx%dv q=%d'
101  cstrJTRC_SOI                     'Start of Image'
102  cstrJTRC_SOS                     'Start Of Scan: %d components'
103  cstrJTRC_SOS_COMPONENT           '    Component %d: dc=%d ac=%d'
104  cstrJTRC_SOS_PARAMS              '  Ss=%d, Se=%d, Ah=%d, Al=%d'
105  cstrJTRC_TFILE_CLOSE             'Closed temporary file %s'
106  cstrJTRC_TFILE_OPEN              'Opened temporary file %s'
107  cstrJTRC_UNKNOWN_IDS             'Unrecognized component IDs %d %d %d, assuming YCbCr'
108  cstrJTRC_XMS_CLOSE               'Freed XMS handle %u'
109  cstrJTRC_XMS_OPEN                'Obtained XMS handle %u'
110  cstrJWRN_ADOBE_XFORM             'Unknown Adobe color transform code %d'
111  cstrJWRN_BOGUS_PROGRESSION       'Inconsistent progression sequence for component %d coefficient %d'
112  cstrJWRN_EXTRANEOUS_DATA         'Corrupt JPEG data: %u extraneous bytes before marker 0x%02x'
113  cstrJWRN_HIT_MARKER              'Corrupt JPEG data: premature end of data segment'
114  cstrJWRN_HUFF_BAD_CODE           'Corrupt JPEG data: bad Huffman code'
115  cstrJWRN_JFIF_MAJOR              'Warning: unknown JFIF revision number %d.%02d'
116  cstrJWRN_JPEG_EOF                'Premature end of JPEG file'
117  cstrJWRN_MUST_RESYNC             'Corrupt JPEG data: found marker 0x%02x instead of RST%d'
118  cstrJWRN_NOT_SEQUENTIAL          'Invalid SOS parameters for sequential JPEG'
119  cstrJWRN_TOO_MUCH_DATA           'Application transferred too many scanlines'


Source:  http://community.borland.com/article/0,1410,20433,00.html

miércoles, 14 de mayo de 2014

extraer imagen o imagenes de un documento word

Para extraer las imagenes de un documento de word la forma más fácil, sencilla y rapida consiste en exportar el documento como HTML. Para ello vamos al menu "Guardar como.." y elegimos la opcion html. Creará una esctructura con todas las imagenes contenidas en el documento de forma aislada que podremos usar a nuestra disposición.


fuente: http://support.microsoft.com/kb/555171/es

lunes, 12 de mayo de 2014

intercalar comillas dobles en una cadena c# (quotes, quotedStr, quoted)

La forma de conseguir intercalar comillas dobles en una cadena es anteponiendo a la cadena el simbolo <arroba> @ y sustituir cada comilla doble por dos comillas dobles.


ejemplo:

 string cadena = "esto es una prueba";

string cadena = @""esto"" es una cadena"; => "esto" es una cadena

podemos repartirlo en varias lineas concatenando cadenas y aplicando el operador @ solamente a las cadenas que lo necesiten....


 string cadena = @""esto"" +
                            " es una " +
                            " cadena";




Fuente: http://stackoverflow.com/questions/3458046/how-to-include-quotes-in-a-string

jueves, 8 de mayo de 2014

¿Como aplicar atributo class a un control ASP.Net?

Para aplicar estilos desde un fichero *.Css a un control ASP debemos utilizar la propiedad CssClass
Veamos el siguiente ejemplo extraido de: http://stackoverflow.com/questions/1648789/how-to-style-textbox-using-css-in-asp-net

<asp:TextBox id="someid" runat="server" CssClass="textbox" />
De esto modo si en el dichero *.aspx tenemos referencia una hoja de estilos, en dicha hoja de estilos podremos hacer algo como .textbox{ width: 500px; } para aplicar el estilo a nuestro control ASP.Net

Configurar un TextBox ASP como PassWord


Si estamos programando una acceso restringido a ciertos bloques de nuestra aplicación, es muy útil utilizar un control para contraseñasa que permita al usuario identificarse sin que "ojos ajenos" puedan conocer sus credenciales de acceso.

¿Como hacemos esto en ASP.Net c#?

Basta con ir a las propiedades del textBox y en la propiedad TextMode seleccionar "Password" entre las opciones disponibles.

Fuente: http://www.daniweb.com/web-development/aspnet/threads/319465/how-to-set-passwordchar-property-to-textbox

miércoles, 7 de mayo de 2014

No se muestran las imagenes ni los estilos *.css en ASP.NET

Tenemos publicada nuestra aplicación web en ASP.Net correctamente publicada con las rutas relativas a imagenes establecidas de forma correcta, los ficheros poseen permisos en servidor para lecturas y ejecución así como exploración de los directorio de imagenes pero aún asi las imagenes y los estilos apuntados por HREF no se cargan.

Puede deberse a una configuración establecida en el web.config

si tenemos definidos un controlador estatico que sirve los contenidos del tipo ...

<httpHandlers>

.......
</httpHandlers>

debemos incluir para que sirva las imagenes y los estilos del siguiente modo..

<httpHandlers>
    <add verb="*" path="*/_images/*.jpg" type="ImageAsyncHandler"/>
    <add verb="GET" path="*.jpg" type="System.Web.StaticFileHandler" /></httpHandlers>


Fuente: http://forums.asp.net/t/1034351.aspx?Using+the+HttpHandler+with+the+JPG+extention

lunes, 5 de mayo de 2014

Error No se pudo analizar el mensaje recibido del servidor

Al colocar un boton para exportar un gridView a Excel nos devuelve el error "No se pudo analizar el mensaje recibido del servidor" la solución es colocar una sentencia Trigger indicando el boton que usamos para exportar con la propiedad PostBackTrigger y lo colocaremos al terminar al etiqueta </ContetTemplate>

Quedando así...


            <asp:UpdatePanel ID="UpdatePanel1" runat="server">
                <ContentTemplate>
                    <div class="ventas">
                            <div>
                                <asp:ImageButton ID="imgImprimirGrid" runat="server" ImageUrl="~/Images/imprimir.jpg" OnClick="imgImprimirGrid_Click" />
                            </div>                      
                       
                            <h3>Informe de ventas de franquicias </h3>

                            <asp:GridView ID="GridView1" runat="server" BackColor="White" BorderColor="#999999" BorderStyle="Solid" BorderWidth="1px" CellPadding="3" Font-Names="Verdana" Font-Size="10px" ForeColor="Black" GridLines="Vertical" Height="151px" OnRowCommand="GridView1_RowCommand" Width="100%">
                                <AlternatingRowStyle BackColor="#DDDDDD" />
                                <FooterStyle BackColor="#CCCCCC" />
                                <HeaderStyle BackColor="#B7E4DD" Font-Bold="True" ForeColor="#666666" />
                                <PagerStyle BackColor="#999999" ForeColor="Black" HorizontalAlign="Center" />
                                <SelectedRowStyle BackColor="#000099" Font-Bold="True" ForeColor="White" />
                                <SortedAscendingCellStyle BackColor="#F1F1F1" />
                                <SortedAscendingHeaderStyle BackColor="#808080" />
                                <SortedDescendingCellStyle BackColor="#CAC9C9" />
                                <SortedDescendingHeaderStyle BackColor="#383838" />
                            </asp:GridView>                      
                       
                    </div>
                </ContentTemplate>
                <Triggers> <asp:PostBackTrigger ControlID="imgImprimirGrid" /> </Triggers>
            </asp:UpdatePanel>

Error El control 'GridView1' debe colocarse dentro de una etiqueta de formulario con runat=server.

La solución es colocar en nuestro fuente el codigo VerifyRenderingInServerForm del siguiente modo:


protected void Page_Load(object sender, EventArgs e){
...
}

public override void VerifyRenderingInServerForm(Control control)
{
  /* Confirms that an HtmlForm control is rendered for the specified ASP.NET
     server control at run time. */
}



Veamos mas detalles para aclararlo


Fuente0: http://stackoverflow.com/questions/6343630/gridview-must-be-placed-inside-a-form-tag-with-runat-server-even-after-the-gri


You are calling GridView.RenderControl(htmlTextWriter), hence the page raises an exception that a Server-Control was rendered outside of a Form.
You could avoid this execption by overriding VerifyRenderingInServerForm
public override void VerifyRenderingInServerForm(Control control)
{
  /* Confirms that an HtmlForm control is rendered for the specified ASP.NET
     server control at run time. */
}
See here and here.


Fuente1: http://aspalliance.com/771_CodeSnip_Exporting_GridView_to_Excel


In this code snippet, I will show how you can export data from a GridView control to a Microsoft Excel spreadsheet.
The Code
Listing 1: Default.aspx
<form id="form1" runat="server">
  <div>
  <asp:GridView ID="GridView1" runat="server">
  </asp:GridView>
  </div>
  <br />
  <asp:Button ID="BtnExport" runat="server" OnClick="BtnExport_Click"
  Text="Export to Excel" />
</form>
Listing 2: Default.aspx.cs
protected void Page_Load(object sender, EventArgs e)
{
  if (!Page.IsPostBack)
  {
    BindData();
  }
}
 
private void BindData()
{
  string query = "SELECT * FROM Categories";
  SqlConnection myConnection = new SqlConnection(ConnectionString);
  SqlDataAdapter ad = new SqlDataAdapter(query, myConnection);
  DataSet ds = new DataSet();
  ad.Fill(ds, "Categories");
  GridView1.DataSource = ds;
  GridView1.DataBind();
}
 
private string ConnectionString
{
  get { return @"Server=localhost;Database=NorthWind;Trusted_Connection=true"; }
 
}
protected void BtnExport_Click(object sender, EventArgs e)
{
  Response.Clear();
  Response.AddHeader("content-disposition""attachment;filename=FileName.xls");
  Response.Charset = "";
 
  // If you want the option to open the Excel file without saving then
  // comment out the line below
  // Response.Cache.SetCacheability(HttpCacheability.NoCache);
  Response.ContentType = "application/vnd.xls";
  System.IO.StringWriter stringWrite = new System.IO.StringWriter();
  System.Web.UI.HtmlTextWriter htmlWrite = new HtmlTextWriter(stringWrite);
  GridView1.RenderControl(htmlWrite);
  Response.Write(stringWrite.ToString());
  Response.End();
}
 
In the above listing, the GridView control will be populated with the data from the Categories table of the Northwind database. You will have to give the appropriate Server name or IP instead of localhost as server name in the above connection string.
If you use this code and try to export the GridView control, you will see an error message saying that the GridView control must be placed inside the form tags with the runat = server attribute.
This is pretty confusing, since your GridView is already inside the form tags and also contains the runat = server attribute. You can easily resolve this error by adding the following lines.
Listing 3: Overiding VerifyRenderingInServerForm Method
public override void VerifyRenderingInServerForm(Control control)
{
  /* Confirms that an HtmlForm control is rendered for the specified ASP.NET
     server control at run time. */
}
Yup, that’s it. Now, when you click the button, the GridView control will be exported correctly. It will prompt you either to open the file as it is or to save it elsewhere.

Fuente2: http://forums.asp.net/t/1016960.aspx?Problem%20with%20GridView%20s%20RenderControl

Jesús Moreno - Ingeniero Ténico Informático - consultor Informático

Hola, soy Jesús Moreno Ingeniero Técnico Informático en sistemas por la US y propietario de éste blog. Mi trabajo en los ultimos años se ...