Saltar al contenido

Condicion If no se cumple


Puche

Recommended Posts

publicado

Hola buenas noches,

Tengo una Macro que realiza registros nuevos, esta misma macro, tiene varias condiciones el cual si en una columna contiene un valor X debe realizar el registro en 2 hojas distintas.

También tiene como condición de que si en el campo "Contacto" el valor introducido no esta en mi base de datos de contactos, me abre un Userform nuevo para realizar el registro nuevo del mismo y posteriormente continua con el registro del "paquete"

Si tengo el Contacto registrado, me cumple bien todas las condiciones, el problema es cuando no tengo el contacto registrado, me hace bien el registro en mi base de datos pero no cumple las condiciones antes mencionadas.

Espero haberme explicado bien :)

Saludos,

 

ExcelPaqueteria.xlsmFetching info...

publicado

Puedes ponerme un ejemplo completo de lo que no se cumple? , y si puedes mostrarlo gráficamente mediante video mejor que mejor. 

publicado

Hola @JSDJSD

No he podido hacerte un video ya que me ocupaba mucho y no me dejaba adjuntar...

He hecho unas capturas que espero te hagan entender mi problema.

Esta captura te muestra un nuevo registro, el cual respeta mis condiciones if ya que tengo el contacto en mi base de datos

111.thumb.jpg.ed423410acaa084d2637411c9df0a0a1.jpg

Te paso el código que tengo para eso

Private Sub bt_agregar_Click() 'AGREGA REGISTROS DE PALAU
Application.ScreenUpdating = False

'DECLARO VARIABLE
    Dim ultimafila As Long
'ASIGNO LA VARIABLE A LA ULTIMA FILA DE LA TABLA
    ultimafila = ActiveSheet.Cells(Rows.Count, "A").End(xlUp).Row + 1
    Sheets("PALAU").Activate
'INSERTA FILA NUEVA
    Range("A2").EntireRow.Insert
'INGRESAR DATOS
    Range("B2").Value = Me.txt_tracking.Value
    Range("C2").Value = Me.txt_trasnportista.Value
    Range("D2").Value = Me.txt_proveedor.Value
    Range("E2").Value = Me.txt_bultos.Value
    Range("F2").Value = Me.txt_contacto.Value
    Range("G2").Value = Me.txt_departamento.Value
    Range("H2").Value = Me.txt_observaciones.Value
    Range("I2").Value = Me.txt_fechaentrega.Value
    Range("J2").Value = Me.txt_recibe.Value
    
    Call box_ubicacionn 'ASIGNA BOX Y UBICACION
         
'APLICO CONDICIONES SEGUN CONTENIDO DE CELDA H2

    If Range("C2") = "DHL" Then
        Sheets("DHL").Activate
        Range("A2").EntireRow.Insert

        Sheets("PALAU").Range("A2:L2").Copy Destination:=Sheets("DHL").Range("A2")
        'Call cargadatos_Hangar
        End If

    If Range("H2") = "HANGAR" Then
        Sheets("HANGAR").Activate
        Range("A2").EntireRow.Insert

        Sheets("PALAU").Range("A2:L2").Copy Destination:=Sheets("HANGAR").Range("A2")
        Call cargadatos_Hangar
        End If

    If Range("H2") = "TERRASSA" Then
        Sheets("TERRASSA").Activate
        Range("A2").EntireRow.Insert
        Sheets("PALAU").Range("A2:L2").Copy Destination:=Sheets("TERRASSA").Range("A2")
        Call cargadatos_Terrassa
        End If

    If Range("H2") = "LLIÇA" Then
        Sheets("LLIÇA").Activate
        Range("A2").EntireRow.Insert
        Sheets("PALAU").Range("A2:L2").Copy Destination:=Sheets("LLIÇA").Range("A2")
        Call cargadatos_Lliça
        End If

    If Range("H2") = "PARETS" Then
        Sheets("PARETS").Activate
        Range("A2").EntireRow.Insert
        Sheets("PALAU").Range("A2:L2").Copy Destination:=Sheets("PARETS").Range("A2")
        Call cargadatos_Parets
        End If

En este caso es cuando no me las respeta. Cuando no tengo el contacto registrado y me salta el UserForm para realizar el registro nuevo

222.thumb.jpg.3aa0ee45b13284687fe12bd6f5c7deeb.jpg

Gracias de antemano,

Saludos!

publicado

@JSDJSD

Muchas gracias, ahora si funciona bien.

Si no te importa podrías decirme cual era la causa?

Por lo que he visto, solo has hecho referencia a la hoja1, ese era el problema?

Saludos y gracias!

Archivado

Este tema está ahora archivado y está cerrado a más respuestas.

  • 109 ¿Te parecen útiles los tips de las funciones? (ver tema completo)

    1. 1. ¿Te parecen útiles los tips de las funciones?


      • No
      • Ni me he fijado en ellos

  • Ayúdanos a mejorar la comunidad

    • Donaciones recibidas este mes: 0.00 EUR
      Objetivo: 130.00 EUR
  • Archivos

  • Estadísticas de descargas

    • Archivos
      188
    • Comentarios
      98
    • Revisiones
      29

    Más información sobre "Cambios en el Control Horario"
    Última descarga
    Por pegones1

    3    1

  • Crear macros Excel

  • Mensajes

    • Saludos @JSDJSD espero estes bien gracias por la solución que propuso para mi pregunta.  Tome el archivo con sus correcciones y al descargarlo verifique no posee una funcionalidad que si estaba en el archivo original de mi pregunta en concreto tiene que ver con la información que debería mostrarse en el TextBox2  de allí que:  Cuando selecciono el código y hago click sobre en el Listbox1  los datos se copian correctamente en los TextBox3 y TextBox5 pero en el TextBox2 no se copia ningun dato revisando me pude percatar que con la macros que agrego no se muestran datos en el TextBox2 a partir de la Columna "G" y cuando se suspende el funcionamiento de la Macro ComboBox1 si se muestran correctamente todos los datos en los TextBox2, 3 y 5 pero en el Listbox1 no se muestran exclusivamente los datos correspondientes al código que se selecciona en el ComboBox1,  mientras que si se suspende el funcionamiento de la Macro BuscarYCargarEnListBox los datos se mostrados en el Listbox1 corresponden exclusivamente al código que se selecciona en el ComboBox1 dichos datos se copian correctamente en los TextBox3 y TextBox5 pero en el TextBox2 no se copia ningun dato
    • Tal y como tienes tu código hace lo siguiente, que es lo que necesitas?
    • Private Sub ComboBox1_Change() Dim hoja As Worksheet Dim fila As Long Dim ultimaFila As Long Dim columnas() As Variant Dim i, ii As Integer Dim codigo As String Dim encontrado As Boolean Set hoja = ThisWorkbook.Sheets("MATRIZ1") codigo = ComboBox1.Value ' Si ComboBox1 está vacío If ComboBox1.Value = "" Then UserForm_Initialize Exit Sub End If ' Si ComboBox1 tiene un valor (código) encontrado = False With ListBox1 ' Limpiar ListBox .RowSource = "" ' Definir ColumnCount para el ListBox .ColumnCount = 6 ' 6 columnas (B, C, D, E, F, M) ' Columnas específicas: B, C, D, E, F, M (números de columna) columnas = Array(2, 3, 4, 5, 6, 13) .ColumnWidths = "70;90;90;90;90;90;0;0;0;0;0;0;0;0" .ColumnHeads = False ' Agregar la cabecera al ListBox (desde la fila 4, columnas B, C, D, E, F, M) .AddItem hoja.Cells(4, columnas(0)).Value ' Columna B For ii = 1 To UBound(columnas) .List(0, ii) = hoja.Cells(4, columnas(ii)).Value ' Añadir encabezados de las otras columnas Next ii ' Determinar última fila con datos en la columna B ultimaFila = hoja.Cells(hoja.Rows.Count, "B").End(xlUp).Row ' Recorrer desde la fila 5 hacia abajo For fila = 5 To ultimaFila If hoja.Cells(fila, 2).Value = codigo Then ' Columna B encontrado = True ' Añadir nueva fila al ListBox (empieza en la segunda fila del ListBox) .AddItem hoja.Cells(fila, columnas(0)).Value ' Columna B For i = 1 To UBound(columnas) ' Asegurarse de que se estén agregando todos los valores correctamente .List(Me.ListBox1.ListCount - 1, i) = hoja.Cells(fila, columnas(i)).Value ' Rellenar las otras columnas Next i End If Next fila End With If Not encontrado Then MsgBox "No se encontró el código en la hoja.", vbInformation End If End Sub  
  • Visualizado recientemente

    • No hay usuarios registrado para ver esta página.
×
×
  • Crear nuevo...

Información importante

Echa un vistazo a nuestra política de cookies para ayudarte a tener una mejor experiencia de navegación. Puedes ajustar aquí la configuración. Pulsa el botón Aceptar, si estás de acuerdo.