¿Cómo convertir un formato de fecha aaaammddhhmmss a una fecha y hora normales en Excel?
En la práctica, es habitual encontrar datos exportados desde otros sistemas o archivos de registro en los que la fecha y la hora aparecen como una cadena continua en formato aaaammddhhmmss. Por ejemplo, «20240630174521» representa el 30/06/2024 a las 17:45:21. Sin embargo, Excel no reconoce automáticamente esta cadena como un valor estándar de fecha y hora, lo que complica su análisis, ordenación o cálculo. Convertir estas cadenas al formato de fecha y hora reconocible por Excel (por ejemplo, dd/mm/aaaa hh:mm:ss) resulta esencial para realizar análisis de datos, filtrados o informes posteriores.
Este artículo ofrece instrucciones prácticas paso a paso para convertir cadenas en formato aaaammddhhmmss al formato estándar de fecha y hora de Excel. Exploramos distintos enfoques: desde fórmulas para una conversión rápida directamente en celdas, hasta soluciones automatizadas con código VBA, pasando por Power Query de Excel para un método más flexible y visual. Cada opción se adapta a diferentes escenarios, según sus necesidades, el volumen de datos y su nivel de familiaridad con las funciones de Excel.

Convertir aaaammddhhmmss a fecha y hora normal Configurar formato de fecha y hora con fórmulas
Código VBA: conversión automática de aaaammddhhmmss a fecha y hora normal Fecha y hora
Convertir aaaammddhhmmss a fecha y hora normal Configurar formato de fecha y hora con fórmulas
Las fórmulas de Excel ofrecen una forma rápida y fiable de dividir y reformatear la cadena aaaammddhhmmss en un valor de fecha y hora que Excel reconoce directamente en su hoja de cálculo, sin necesidad de complementos externos ni herramientas avanzadas. Este enfoque es ideal para conjuntos de datos relativamente pequeños o cuando se busca una transformación manual, transparente y fácil de auditar.
Para convertir la cadena, introduzca la siguiente fórmula en una celda vacía (por ejemplo, en la celda B2 si su valor original en formato aaaammddhhmmss está en la celda A2):
=TEXT(DATE(LEFT(A2,4),MID(A2,5,2),MID(A2,7,2))+TIME(MID(A2,9,2),MID(A2,11,2),MID(A2,13,2)),"dd/mm/yyyy hh:mm:ss") Instrucciones: Después de introducir la fórmula, pulse Intro para confirmarla. Si tiene una lista de valores en formato aaaammddhhmmss en la columna A, arrastre el controlador de relleno desde la celda B2 hacia abajo para aplicar rápidamente la fórmula al resto de filas. Cada resultado le mostrará la fecha y hora con formato como texto.
Este método resulta muy útil para tareas puntuales de limpieza de datos, listas pequeñas o situaciones en las que desee mantener la cadena original intacta en una columna y disponer del valor con formato en otra. Posible inconveniente: el resultado de la fórmula sigue siendo texto; si necesita un valor real de fecha y hora de Excel para realizar cálculos (como diferencias temporales), es posible que deba convertir dicho texto a un formato numérico.

Explicación de parámetros y consejos:
- IZQUIERDA(A2;4): extrae el año de 4 dígitos
- EXTRAE(A2;5,2): extrae el mes de 2 dígitos
- EXTRAE(A2;7,2): extrae el día de 2 dígitos
- EXTRAE(A2;9,2): extrae la hora de 2 dígitos
- EXTRAE(A2;11,2): extrae el minuto de 2 dígitos
- EXTRAE(A2;13,2): extrae el segundo de 2 dígitos
- La función TEXTO() da formato al resultado como una cadena de fecha y hora fácil de leer.
Posibles problemas: Si alguno de los valores originales no tiene exactamente 14 dígitos (por ejemplo, si se omiten ceros iniciales o se introducen accidentalmente como números en notación científica), las fórmulas podrían devolver resultados incorrectos o errores. Compruebe la coherencia de los datos de entrada antes de aplicar la transformación basada en fórmulas.
Alternativamente, si sus datos tienen siempre exactamente 14 dígitos, esta fórmula más corta convierte la cadena y devuelve un valor serial de fecha y hora de Excel (no texto):
=--TEXT(A2,"0000\-00\-00\ 00\:00\:00") Cómo usarla: Tras introducir esta fórmula en una celda (por ejemplo, B2), pulse Intro. A continuación, es posible que deba dar formato a la(s) celda(s) resultante(s) como DD/MM/AAAA HH:MM:SS mediante el cuadro de diálogo Establecer formato de celda para mostrar el valor en un formato legible. Para ello, seleccione las celdas con el resultado, haga clic con el botón derecho, elija Establecer formato de celda > Personalizada e introduzca dd/mm/aaaa hh:mm:ss como código de formato.

Este segundo método es especialmente eficaz si desea un valor real de fecha en lugar de una cadena de texto.

Consejo: Si va a utilizar los resultados convertidos en cálculos posteriores con fechas (por ejemplo, restar fechas o calcular duraciones), utilice siempre la fórmula que devuelve un número serial (la segunda fórmula) y, a continuación, aplíquele el formato necesario.
Resolución de problemas: Si obtiene errores, asegúrese de que sus datos de origen sean realmente texto y no contengan caracteres no numéricos. Los espacios iniciales o finales también pueden afectar a los resultados; considere limpiar los datos usando ESPACIOS(A2) dentro de la fórmula si sospecha que este es el problema.
Código VBA: conversión automática de aaaammddhhmmss a fecha y hora normal Fecha y hora
Para usuarios que necesiten gestionar grandes volúmenes de datos o deseen automatizar la conversión, VBA (Visual Basic para Aplicaciones) ofrece una solución flexible: al recorrer en bucle las celdas seleccionadas, convierte cada valor en formato aaaammddhhmmss en una fecha y hora estándar de Excel, ya sea en su ubicación original o en una columna de destino. Este enfoque resulta especialmente útil para evitar introducir fórmulas en múltiples celdas o cuando los datos se actualizan con frecuencia.
Este método es ideal para grandes volúmenes de datos o necesidades recurrentes. Sin embargo, el uso de VBA requiere habilitar macros, algo que podría estar restringido por las políticas de su organización o la configuración de Excel. Antes de ejecutar cualquier código VBA, recuerde guardar su archivo, ya que los cambios no siempre son fácilmente reversibles.
Pasos a seguir:
- Seleccione el rango de valores en formato aaaammddhhmmss de su hoja de cálculo que necesite convertir (por ejemplo, A2:A100).
- Haga clic en la pestaña Programador y luego en Visual Basic para abrir el editor de VBA. En el panel izquierdo, busque su libro de trabajo, haga clic con el botón derecho y seleccione Insertar > Módulo. En la ventana de código, pegue el siguiente código:
Sub Convert_yyyymmddhhmmss_To_DateTime()
Dim rng As Range
Dim cell As Range
Dim strDate As String
Dim y As Integer
Dim m As Integer
Dim d As Integer
Dim hh As Integer
Dim mm As Integer
Dim ss As Integer
On Error Resume Next
xTitleId = "KutoolsforExcel"
Set rng = Application.InputBox("Select the range of yyyymmddhhmmss values to convert:", xTitleId, Selection.Address, Type:=8)
For Each cell In rng
strDate = Trim(cell.Value)
If Len(strDate) = 14 And IsNumeric(strDate) Then
y = CInt(Left(strDate, 4))
m = CInt(Mid(strDate, 5, 2))
d = CInt(Mid(strDate, 7, 2))
hh = CInt(Mid(strDate, 9, 2))
mm = CInt(Mid(strDate, 11, 2))
ss = CInt(Mid(strDate, 13, 2))
cell.Value = DateSerial(y, m, d) + TimeSerial(hh, mm, ss)
cell.NumberFormat = "dd/mm/yyyy hh:mm:ss"
End If
Next cell
End Sub Tras pegar el código, cierre el editor de VBA. Vuelva a Excel y ejecute la macro pulsando Alt + F8, seleccionando "Convertir_aaaammddhhmmss_A_FechaHora" y haciendo clic en Ejecutar. La macro le pedirá que seleccione el rango y transformará cada cadena numérica de 14 dígitos en un valor legible de fecha y hora directamente en su ubicación.
Consejos y resolución de problemas:
- Si algunos valores no se convierten, compruebe que su longitud sea exactamente de 14 dígitos, asegúrese de que no contengan espacios adicionales y confirme que todos los caracteres sean numéricos.
- Puede copiar los valores de fecha y hora convertidos a otra columna antes de ejecutar la macro si desea conservar intactos los originales.
- Guarde siempre su libro de trabajo antes de ejecutar macros y asegúrese de que las macros estén habilitadas en Excel.
Ventajas: Procesa rápidamente grandes rangos y es fácil de automatizar para tareas repetitivas.
Desventajas: Requiere habilitar macros y no siempre resulta adecuado en entornos con restricciones de seguridad para macros.

Descubra la magia de Excel con KUTOOLS AI
- Ejecución inteligente: Realice operaciones en celdas, analice datos y cree gráficos con comandos sencillos.
- fórmulas personalizadas: Cree fórmulas a medida para optimizar sus flujos de trabajo.
- Programación en VBA: Escriba e implemente código VBA con facilidad.
- Interpretación de fórmulas: Entienda las fórmulas complejas con facilidad.
- Traducción de texto: Rompa las barreras del idioma directamente en sus hojas de cálculo.
Las mejores herramientas de productividad para Office
Potencie sus habilidades en Excel con Kutools para Excel y experimente una eficiencia como nunca antes.Kutools para Excel ofrece más de 300 funciones avanzadas para aumentar su productividad y Ahorrar tiempo.Haga clic aquí para obtener la función que más necesita...
Office Tab aporta una interfaz con pestañas a Office y hace que su trabajo sea mucho más fácil
- Active la edición y lectura con pestañas en Word, Excel, PowerPoint, Publisher, Access, Visio y Project.
- Abra y cree varios documentos en nuevas pestañas dentro de la misma ventana, en lugar de hacerlo en ventanas separadas.
- ¡Aumente su productividad en un 50 % y elimine cientos de clics del ratón cada día!
Todos los complementos de Kutools en un solo instalador.
Kutools for Office es la suite que incluye complementos para Excel, Word, Outlook y PowerPoint, además de Office Tab Pro, ideal para equipos que trabajan en distintas aplicaciones de Office.
- Suite integral— complementos para Excel, Word, Outlook y PowerPoint + Office Tab Pro
- Un instalador, una licencia— configuración en minutos (compatible con MSI)
- Rendimiento mejorado en conjunto— productividad optimizada en todas las aplicaciones de Office
- Prueba gratuita de 30 días con todas las funciones— sin registro ni tarjeta de crédito
- La mejor relación calidad-precio— ahorre frente a la compra individual de complementos