Es muy común que tengas que enviar varios correos dependiendo de una condición, por ejemplo, puede ser un estatus, lo que se puede condicionar desde Excel para ser enviados desde Outlook.
Envío de correos desde Excel.
Cuando tu lista de registros a revisar es considerablemente larga y quieres enviar todos esos correos con un solo clic, entonces es indispensable contar con una macro que nos ayude.
En el siguiente ejemplo te muestro como enviar un correo dependiendo si el estatus del registro está en “Pendiente”.
Suponiendo la siguiente base de datos:
La siguiente macro revisará cada registro y si en la columna “E”, el Estatus es igual a “Pendiente”, entonces enviará un correo personalizado al email que se encuentra en la columna “B”.
La macro es la siguiente:
Sub Enviar_Correos()
For i = 2 To Range("A" & Rows.Count).End(xlUp).Row
If Cells(i, "E").Value = "Pendiente" Then
Set dam = CreateObject("outlook.application").createitem(0)
dam.To = Cells(i, "B").Value 'Destinatarios
dam.Subject = "Recordatorio de seguimiento a pendientes"
dam.Body = "Estimado/a : " & Cells(i, "A").Value & vbCr & vbCr & _
"Le recordamos que tiene pendiente " & _
"el siguiente requerimiento : " & Cells(i, "C").Value & vbCr & vbCr & _
"Saludos cordiales"
dam.Send 'El correo se envía en automático
'dam.Display 'El correo se muestra
End If
Next
MsgBox "Correos enviados"
End Sub
Sigue las Instrucciones para un botón y ejecutar la macro
- Abre tu libro de Excel
- Para abrir Vba-macros y poder pegar la macro, Presiona Alt + F11
- En el menú elige Insertar / Módulo
- En el panel del lado derecho copia la macro
- Ahora para crear un botón, puedes hacer lo siguiente:
- Inserta una imagen en tu libro, elige del menú Insertar / Imagen / Autoformas
- Elige una imagen y con el Mouse, dentro de tu hoja, presiona click y arrastra el Mouse para hacer grande la imagen.
- Una vez que insertaste la imagen en tu hoja, dale clic derecho dentro de la imagen y selecciona: Tamaño y Propiedades. En la ventana que se abre selecciona la pestaña: Propiedades. Desmarca la opción “Imprimir Objeto”. Presiona “Cerrar”
- Vuelve a presionar clic derecho dentro de la imagen y ahora selecciona: Asignar macro. Selecciona: Enviar Correos
- Aceptar.
- Guarda tu archivo como Excel habilitado para macros.
- Para ejecutar la macro presiona clic en la imagen.
El resultado será algo como esto:
Quiero reenviar correos electrónicos que ingresan a mi cuenta de forma aleatoria a tres correos distintos. ¿Algún ayuda?
No comprendemos exactamente cómo seleccionaría los correos y los destinatarios, pero aquí sugerimos una modificación de la macro original:
Dim destinatarios() As Variant
Dim i As Integer
Dim index As Integer
Dim dam As Object
Dim cantidadDestinatarios As Integer
Dim j As Integer
‘ Definir la cantidad de destinatarios deseados (en este caso, 3)
cantidadDestinatarios = 3
‘ Definir los destinatarios
destinatarios = Range(“B2:B” & Range(“B” & Rows.Count).End(xlUp).Row).Value
‘ Semilla para generar números aleatorios
Randomize
‘ Bucle principal para enviar correos
For i = 2 To Range(“A” & Rows.Count).End(xlUp).Row
If Cells(i, “E”).Value = “Pendiente” Then
‘ Bucle para enviar a la cantidad de destinatarios especificada
For j = 1 To cantidadDestinatarios
‘ Generar índice aleatorio
index = Int((UBound(destinatarios) – LBound(destinatarios) + 1) * Rnd + LBound(destinatarios))
‘ Crear objeto de aplicación Outlook y correo
Set dam = CreateObject(“outlook.application”).CreateItem(0)
‘ Asignar destinatario aleatorio
dam.To = destinatarios(index, 1)
‘ Configurar el resto del correo
dam.Subject = “Recordatorio de seguimiento a pendientes”
dam.Body = “Estimado/a : ” & Cells(i, “A”).Value & vbCr & vbCr & _
“Le recordamos que tiene pendiente ” & _
“el siguiente requerimiento : ” & Cells(i, “C”).Value & vbCr & vbCr & _
“Saludos cordiales”
‘ Enviar el correo
dam.Send
Next j
End If
Next i
‘ Mensaje de confirmación
MsgBox “Correos enviados”
End Sub
Hola, ¿cómo se modificaría el código para enviar el correo con copia a otros correos electrónicos? Agrego las columnas correspondientes a los correos de las personas a quienes se les enviará copia, pero en el código, ¿cómo lo podría realizar?
Saludos.
Para enviar correos con copia (CC) o con copia oculta (BCC), se debe utilizar el método add_header() del objeto de correo, que es $mail en este caso. Por ejemplo: $mail->addCC(‘email@ejemplo.com’); // Para CC $mail->addBCC(‘email@ejemplo.com’); // Para BCC En la función anterior sólo hay que cambiar email@ejemplo.com por una variable que contenga el valor correspondiente a cada fila del archivo CSV.
Para enviar un correo con copia (CC) a otros destinatarios, se puede utilizar el método add_header para agregar la cabecera “Cc” al mensaje. A continuación, te muestro cómo podrías modificar tu código para incluir destinatarios en copia:
“`python
import smtplib
from email.mime.multipart import MIMEMultipart
from email.mime.text import MIMEText
# Datos de conexión SMTP
smtp_server = ‘smtp.example.com’
smtp_port = 587
username = ‘tu_usuario@example.com’
password = ‘tu_contraseña’
# Crear objeto servidor SMTP y conectarse al servidor.
server = smtplib.SMTP(smtp_server, smtp_port)
server.starttls()
server.login(username, password)
# Leer datos del archivo CSV o Excel aquí…
for index, row in df.iterrows():
# Crear el mensaje multipart/mixed
msg = MIMEMultipart()
# Configurar los campos del mensaje.
msg[‘From’] = username # Remitente es siempre tu dirección de correo electrónico.
msg[‘To’] = row[‘destinatario_email’]
# Agregar múltiples direcciones en Cc separadas por comas o punto y coma según sea necesario.
cc_emails=row.get(‘cc_email’, ”) # Cambia esto según tus columnas reales
if cc_emails:
msg.add_header(‘Cc’, ‘, ‘.join(cc_emails.split(‘,’)))
subject= f’Asunto {row[“nombre”]}’
msg[‘Subject’] = subject
body_content=f’Hola {row[“nombre”]}, este es su contenido personalizado.’
msg.attach(MIMEText(body_content, ‘plain’))
try:
server.sendmail(msg[‘From’], [msg[‘To’]] + [x.strip() for x in cc_emails.split(‘,’)], msg.as_string())
except Exception as e:
print(f’Ocurrió un error al enviar el correo a {row[“destinatario_email”]}: {str(e)}’)
“`
En este código he agregado una nueva columna llamada `cc_email` que contiene las direcciones de correo electrónico a las que deseas enviar una copia. Puedes cambiar esta columna según tus necesidades.
Recuerda que debes separar cada dirección de correo electrónico con una coma (,).
Gracias, me ha funcionado, perfecto.
¿Alguien sabe cómo puedo adjuntar una imagen en ese correo?
Para adjuntar una imagen en un correo electrónico, sigue estos pasos generales que son similares en la mayoría de los servicios de correo como Gmail, Outlook o Yahoo Mail:
1. **Abre tu servicio de correo**: Inicia sesión en tu cuenta de correo electrónico.
2. **Redacta un nuevo mensaje**: Haz clic en “Redactar” o “Nuevo mensaje”.
3. **Adjuntar archivo**:
– Busca el ícono que representa un clip (generalmente está cerca del área donde escribes el destinatario y el asunto).
– Haz clic en ese ícono.
– Se abrirá una ventana para explorar archivos; busca la imagen que deseas adjuntar desde tus carpetas locales y selecciónala.
– También puedes arrastrar directamente las imágenes desde tu carpeta al cuerpo del email si estás utilizando un cliente web.
4. **Espera a que se cargue**: Asegúrate de esperar a que se complete la carga antes de enviar el mensaje.
5. **Envía el correo**: Una vez adjuntada la imagen, completa cualquier otro detalle necesario y haz clic en “Enviar”.
Recuerda no exceder los límites permitidos por cada proveedor respecto al tamaño máximo permitido para archivos adjuntos, ya sea individualmente o sumando todos los archivos enviados conjuntamente.
Para adjuntar una imagen en un correo electrónico, sigue estos pasos generales que se aplican a la mayoría de los servicios de correo como Gmail, Outlook, Yahoo Mail, etc.: 1. **Abre tu servicio de correo**: Inicia sesión en tu cuenta de correo electrónico. 2. **Redacta un nuevo mensaje**: Haz clic en “Redactar” o “Nuevo mensaje”. Esto abrirá una nueva ventana o sección para escribir tu correo. 3. **Adjunta la imagen**: Busca el icono que representa un clip (📎) o algo similar que indique “adjuntar archivo”. Este ícono suele estar ubicado cerca del área donde escribes el texto del email.
4. **Selecciona la imagen**: Al hacer clic en el icono de adjunto, se abrirá una ventana exploradora donde podrás buscar y seleccionar la imagen que deseas enviar desde tu computadora o dispositivo móvil.
5. **Espera a que se cargue**: Una vez seleccionada la imagen, espera unos momentos mientras se carga al mensaje; esto puede tardar dependiendo del tamaño del archivo y velocidad de conexión a Internet.
6. **Envía el mensaje**: Cuando hayas terminado con todo lo anterior y estés satisfecho con el contenido del mensaje junto con las imágenes adjuntas, haz clic en “Enviar” para enviarlo.
Recuerda no enviar archivos demasiado grandes ya que algunos proveedores tienen límites máximos sobre los tamaños permitidos para archivos adjuntos.
Buen día. ¿Ustedes venden formatos para liquidaciones de prestaciones sociales y vacaciones?
claudiaoro34@hotmail.com
No vendemos ningún formato. Los formatos que tenemos los puede descargar gratis desde esta página.
Buen día.
Hola, ¿ustedes venden formatos para liquidaciones y prestaciones sociales?
claudiaoro34@hotmail.com
No vendemos formatos ni herramientas para liquidar prestaciones sociales. No hemos desarrollado ninguna herramienta en línea para ello, pero puede consultar las que hay disponibles en la web.
Hola, buenas tardes. Si en el ejemplo que ponen en la base de datos el nombre de Daniel apareciera dos o más veces con diferentes conceptos pendientes (factura, nota, pedido, etc.), ¿cómo se podría enviar todo en un solo correo? Es decir, que el resultado fuera algo como esto:
Para: Daniel@gmail.com
Asunto: Requerimiento de seguimiento a pendientes
Estimado/a Daniel:
Le recordamos que tiene pendiente el siguiente requerimiento:
– Factura
– Pedido
– Nota
Saludos cordiales.
Para enviar un solo correo con varios conceptos pendientes para el mismo destinatario, puede utilizar una lista o tabla en el cuerpo del correo. Aquí hay un ejemplo de cómo podría estructurarse:
“`plaintext
Para: Daniel@gmail.com
Asunto: Requerimiento de seguimiento a pendientes
Estimado/a Daniel:
Le recordamos que tiene pendiente los siguientes requerimientos:
| Concepto | Descripción |
|———–|————————————-|
| Factura | Envío de la factura correspondiente.|
| Pedido | Confirmación del pedido realizado. |
| Nota | Revisión de la nota enviada anteriormente.|
Por favor, no dude en contactarnos si necesita más información.
Saludos cordiales.
“`
En este caso, se utiliza una tabla simple (con líneas verticales y guiones) para organizar la información y hacerla más legible. Asegúrese de ajustar el formato según las capacidades del cliente de correo electrónico que esté utilizando, ya que algunos pueden tener limitaciones en cuanto al formato enriquecido o HTML.
Si está utilizando un lenguaje como Python para automatizar esto (por ejemplo usando smtplib), necesitaría construir el cuerpo del mensaje como una cadena formateada adecuadamente con saltos de línea (`\n`) donde sea necesario.
¿Te gustaría ver algún código específico sobre cómo implementar esto?
Para enviar un solo correo con varios conceptos pendientes para el mismo destinatario, puedes modificar la función `enviar_correo` para que acepte una lista de conceptos y luego formatear el cuerpo del mensaje en consecuencia. Aquí tienes un ejemplo de cómo hacerlo:
“`python
import smtplib
from email.mime.text import MIMEText
def enviar_correo(destinatario, concepto):
# Configuración del servidor SMTP
smtp_server = ‘smtp.gmail.com’
smtp_port = 587
username = ‘tu_email@gmail.com’ # Cambia esto por tu dirección de correo electrónico.
password = ‘tu_contraseña’ # Cambia esto por tu contraseña.
# Crear el objeto del mensaje.
msg = MIMEText(concepto)
msg[‘Subject’] = “Requerimiento de seguimiento a pendientes”
msg[‘From’] = username
msg[‘To’] = destinatario
try:
with smtplib.SMTP(smtp_server, smtp_port) as server:
server.starttls() # Iniciar TLS (Transport Layer Security)
server.login(username, password) # Autenticarse en el servidor SMTP.
server.sendmail(msg[‘From’], [msg[‘To’]], msg.as_string()) # Enviar el correo.
print(f”Correo enviado a {destinatario} con los siguientes conceptos:\n{conceptos}\n”)
except Exception as e:
print(f”No se pudo enviar el correo a {destinatario}. Error: {e}”)
# Lista de correos electrónicos y sus respectivos conceptos pendientes.
pendientes_por_enviar = {
“Daniel@gmail.com”: [“Factura”, “Pedido”, “Nota”],
“Juan@gmail.com”: [“Informe Técnico”, “Cotización”]
}
for destinatario, conceptos in pendientes_por_enviar.items():
concepto_formateado= “\n”.join(conceptos) # Formatea la lista como una cadena separada por saltos de línea
enviar_correo(destinatario, concepto_formateado)
“`
### Descripción del código:
1. **Pendientes por Enviar:** Se define un diccionario donde cada clave es una dirección de correo electrónico y su valor es una lista con los diferentes conceptos asociados.
2. **Enviar Correo:** La función `enviar_correo` ahora acepta dos parámetros: `destinatario`, que es la dirección