Acceder a Tabla desde Celda y Agregar Valores en su Interior usando Desplazamientos de Fila y Columna
Normalmente, agrega valores dentro de la Tabla u Objeto de Lista usando el método Cell.PutValue(). Pero a veces, es posible que necesite agregar valores dentro de la Tabla u Objeto de Lista usando los desplazamientos de fila y columna.
Para acceder a una Tabla u Objeto de Lista desde una celda, utilice el método Cell.GetTable(). Para agregar valores dentro de ella utilizando los desplazamientos de fila y columna, use el método ListObject.PutCellValue.
La siguiente captura de pantalla muestra el archivo de Excel fuente usado dentro del código. Contiene la tabla vacía y resalta la celda D5 que se encuentra dentro de la tabla. Accederemos a esta tabla desde la celda D5 usando el método Cell.GetTable() y luego agregaremos los valores dentro de ella usando los métodos Cell.PutValue() y ListObject.PutCellValue.
Ejemplo
Capturas de pantalla que comparan los archivos fuente y de salida
![]() |
|---|
La siguiente captura de pantalla muestra el archivo de Excel de salida generado por el código. Como se puede ver, la celda D5 tiene un valor y la celda F6, que está en el desplazamiento 2,2 de la tabla, tiene un valor.
![]() |
|---|
Código C# para acceder a la tabla desde la celda y para agregar valores dentro de ella usando desplazamientos de fila y columna
El siguiente código de ejemplo carga el archivo de Excel fuente como se muestra en la captura de pantalla anterior y agrega valores dentro de la tabla, y genera el archivo de Excel de salida como se muestra arriba.
| // For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-.NET | |
| // The path to the documents directory. | |
| string dataDir = "./"; | |
| // Create workbook from source Excel file | |
| Workbook workbook = new Workbook(dataDir + "source.xlsx"); | |
| // Access first worksheet | |
| Worksheet worksheet = workbook.Worksheets[0]; | |
| // Access cell D5 which lies inside the table | |
| Cell cell = worksheet.Cells["D5"]; | |
| // Put value inside the cell D5 | |
| cell.PutValue("D5 Data"); | |
| // Access the Table from this cell | |
| ListObject table = cell.GetTable(); | |
| // Add some value using Row and Column Offset | |
| table.PutCellValue(2, 2, "Offset [2,2]"); | |
| // Save the workbook | |
| workbook.Save(dataDir + "output_out.xlsx"); |

