Jump to content
Jose BN

ANSWERED Copiar datos de una hoja a otra si el valor es mayor a 0

Recommended Posts

Buenos días!

 

Amigos del foro quisiera solicitarles el apoyo para resolver el siguiente problema, necesito una macro que me permita copiar de una hoja a otra si se cumplen los siguientes criterios:

  • Si el valor en la columna G de la hoja Diario es mayor que cero, se copien los datos de Diario(hasta la ultima celda con datos) a la hoja BD pegando los datos en la ultima celda vacía de BD.
  • Al copiar aquellos valores mayores a cero en la hoja BD quitarlos de la hoja Diario, solamente dejando los datos que contengan cero o se encuentren vacios en la columna G de la hoja Diario.

Lo estuve intentando de la siguiente manera:

Sub copiar2()

    Set J1 = Sheets("Diario")
    Set J2 = Sheets("BD")
    j = J2.Range("A" & Rows.Count).End(xlUp).Row + 1
    For i = 3 To 79
        If J1.Cells(i, "G") > 0 Then
            J2.Cells(i, "A") = J1.Cells(i, "A")
            J2.Cells(i, "B") = J1.Cells(i, "B")
            J2.Cells(i, "C") = J1.Cells(i, "C")
            J2.Cells(i, "D") = J1.Cells(i, "D")
            J2.Cells(i, "E") = J1.Cells(i, "E")
            J2.Cells(i, "F") = J1.Cells(i, "F")
            J2.Cells(i, "G") = J1.Cells(i, "G")
            J2.Cells(i, "H") = J1.Cells(i, "H")
            J2.Cells(i, "I") = J1.Cells(i, "I")
            J2.Cells(i, "J") = J1.Cells(i, "J")
            J2.Cells(i, "K") = J1.Cells(i, "K")
            J2.Cells(i, "L") = J1.Cells(i, "L")
            J2.Cells(i, "M") = J1.Cells(i, "M")
            J2.Cells(i, "N") = J1.Cells(i, "N")
        End If
    Next
    MsgBox "Valores copiados"
End Sub

Saludos

JB

Consulta copiado.xlsm

Share this post


Link to post
Share on other sites

Checa el archivo:

Sub Copia()
Application.ScreenUpdating = False
Dim Uf As String
Dim Ul As Long

    Ul = Hoja2.Range("G" & Rows.Count).End(xlUp).Row + 2
            Uf = Hoja1.Range("G" & Rows.Count).End(xlUp).Row
                Hoja1.Range("A2:N" & Uf).AutoFilter Field:=7, Criteria1:=">0"
                    Hoja1.Range("A3:N10000").SpecialCells(xlCellTypeVisible).Copy Destination:=Hoja2.Cells(Ul, 1)

Hoja1.Range("A3:N" & Uf).EntireRow.Delete
Hoja1.Range("A2:N" & Uf).AutoFilter

Application.ScreenUpdating = True
End Sub

 

Copia de Consulta copiado.xlsm

Share this post


Link to post
Share on other sites
Hace 56 minutos , DiegoLG dijo:

Checa el archivo:


Sub Copia()
Application.ScreenUpdating = False
Dim Uf As String
Dim Ul As Long

    Ul = Hoja2.Range("G" & Rows.Count).End(xlUp).Row + 2
            Uf = Hoja1.Range("G" & Rows.Count).End(xlUp).Row
                Hoja1.Range("A2:N" & Uf).AutoFilter Field:=7, Criteria1:=">0"
                    Hoja1.Range("A3:N10000").SpecialCells(xlCellTypeVisible).Copy Destination:=Hoja2.Cells(Ul, 1)

Hoja1.Range("A3:N" & Uf).EntireRow.Delete
Hoja1.Range("A2:N" & Uf).AutoFilter

Application.ScreenUpdating = True
End Sub

Diego igual muchas gracias! 

Copia de Consulta copiado.xlsm 39.44 kB · 2 descargas

 

Share this post


Link to post
Share on other sites
Guest
This topic is now closed to further replies.

INFORMACIÓN BÁSICA SOBRE PROTECCIÓN DE DATOS

Responsable: Sergio Andrés Celemín

Finalidad: Moderar y responder comentarios de usuarios. Recuerda que la información que facilites es pública, y los datos que incluyas los leerá cualquier visitante de esta web, así como el avatar que poseas.

Legitimación: Consentimiento del interesado.

Destinatarios: Hetzner Online GmbH.

Derechos: Puedes ejercitar en cualquier momento tus derechos de acceso,
rectificación, supresión, oposición y demás derechos legalmente establecidos a
través del email sergio@ayudaexcel.com.

Información adicional: Encontrarás más información en la política de privacidad.




  • Posts

    • Amigos, estoy muy agradecido con todos por tratar de ayudarme a resolver el dilema de ocultar la contraseña en el ImputBox. Desafortunadamente ninguna de las soluciones me llevo al exito. Pero, la buena noticia es que trasteando un poco en la red, encontre la solucion, y se las dejo por si alguien la necesita.   Option Explicit'---------------------------------- 'API CONSTANTS FOR PRIVATE INPUTBOX '---------------------------------- #If VBA7 Then Private Declare PtrSafe Function CallNextHookEx Lib "user32" (ByVal hHook As LongPtr, _ ByVal ncode As Long, ByVal wParam As LongPtr, lParam As Any) As LongPtr Private Declare PtrSafe Function GetModuleHandle Lib "kernel32" Alias _ "GetModuleHandleA" (ByVal lpModuleName As String) As LongPtr Private Declare PtrSafe Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" _ (ByVal idHook As Long, ByVal lpfn As LongPtr, ByVal hmod As LongPtr, ByVal dwThreadId As Long) As LongPtr Private Declare PtrSafe Function UnhookWindowsHookEx Lib "user32" (ByVal hHook As LongPtr) As Long Private Declare PtrSafe Function SendDlgItemMessage Lib "user32" Alias "SendDlgItemMessageA" _ (ByVal hDlg As LongPtr, ByVal nIDDlgItem As Long, ByVal wMsg As Long, ByVal wParam As LongPtr, ByVal lParam As LongPtr) As LongPtr Private Declare PtrSafe Function GetClassName Lib "user32" Alias "GetClassNameA" _ (ByVal hwnd As LongPtr, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long Private Declare PtrSafe Function GetCurrentThreadId Lib "kernel32" () As Long #Else Private Declare Function CallNextHookEx Lib "user32" (ByVal hHook As Long, _ ByVal ncode As Long, ByVal wParam As Long, lParam As Any) As Long Private Declare Function GetModuleHandle Lib "kernel32" Alias _ "GetModuleHandleA" (ByVal lpModuleName As String) As Long Private Declare Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" _ (ByVal idHook As Long, ByVal lpfn As Long, ByVal hmod As Long, _ ByVal dwThreadId As Long) As Long Private Declare Function UnhookWindowsHookEx Lib "user32" (ByVal hHook As Long) As Long Private Declare Function SendDlgItemMessage Lib "user32" Alias "SendDlgItemMessageA" _ (ByVal hDlg As Long, ByVal nIDDlgItem As Long, ByVal wMsg As Long, _ ByVal wParam As Long, ByVal lParam As Long) As Long Private Declare Function GetClassName Lib "user32" Alias "GetClassNameA" _ (ByVal hwnd As Long, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long Private Declare Function GetCurrentThreadId Lib "kernel32" () As Long #End If 'Constants to be used in our API functions Private Const EM_SETPASSWORDCHAR = &HCC Private Const WH_CBT = 5 Private Const HCBT_ACTIVATE = 5 Private Const HC_ACTION = 0 #If VBA7 Then Private hHook As LongPtr #Else Private hHook As Long #End If '---------------------------------- 'PRIVATE PASSWORDS FOR INPUTBOX '---------------------------------- '//////////////////////////////////////////////////////////////////// 'Password masked inputbox 'Allows you to hide characters entered in a VBA Inputbox. ' 'Code written by Daniel Klann 'March 2003 '64-bit modifications developed by Alexey Tseluiko 'and Ryan Wells (wellsr.com) 'February 2019 '//////////////////////////////////////////////////////////////////// #If VBA7 Then Public Function NewProc(ByVal lngCode As Long, ByVal wParam As Long, ByVal lParam As Long) As LongPtr #Else Public Function NewProc(ByVal lngCode As Long, ByVal wParam As Long, ByVal lParam As Long) As Long #End If Dim RetVal Dim strClassName As String, lngBuffer As Long If lngCode < HC_ACTION Then NewProc = CallNextHookEx(hHook, lngCode, wParam, lParam) Exit Function End If strClassName = String$(256, " ") lngBuffer = 255 If lngCode = HCBT_ACTIVATE Then 'A window has been activated RetVal = GetClassName(wParam, strClassName, lngBuffer) If Left$(strClassName, RetVal) = "#32770" Then 'This changes the edit control so that it display the password character *. 'You can change the Asc("*") as you please. SendDlgItemMessage wParam, &H1324, EM_SETPASSWORDCHAR, asc("*"), &H0 End If End If 'This line will ensure that any other hooks that may be in place are 'called correctly. CallNextHookEx hHook, lngCode, wParam, lParam End Function Function InputBoxDK(Prompt, Title) As String #If VBA7 Then Dim lngModHwnd As LongPtr #Else Dim lngModHwnd As Long #End If Dim lngThreadID As Long lngThreadID = GetCurrentThreadId lngModHwnd = GetModuleHandle(vbNullString) hHook = SetWindowsHookEx(WH_CBT, AddressOf NewProc, lngModHwnd, lngThreadID) InputBoxDK = InputBox(Prompt, Title) UnhookWindowsHookEx hHook End Function Adicionalmente dejo el link de la pagina de donde lo extraje, y el archivo con el codigo para que lo vean. Solucion Un abrazo, y de nuevo muchas gracias a todos. Tema solucionado!     Inputbox funcionando.xlsm
    • Hola Tu Office es de 64 bits y en el archivo de ejemplo enviado hay varias funciones de la API de Windows que hay que modificar en las declaraciones. Modifica toda la parte que está entre la línea #If VBA7 Then y la línea #Else reemplazando por las siguientes: Private Declare PtrSafe Function SetCurrentDirectoryA Lib "kernel32" (ByVal lpPathName As String) As Long Private Declare PtrSafe Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As LongPtr Private Declare PtrSafe Function PostMessage Lib "user32" Alias "PostMessageA" (ByVal hWnd As LongPtr, ByVal wMsg As Long, ByVal wParam As LongPtr, ByVal lParam As LongPtr) As Long Private Declare PtrSafe Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As LongPtr Private Declare PtrSafe Function TerminateProcess Lib "kernel32" (ByVal hProcess As LongPtr, ByVal uExitCode As Long) As Long Private Declare PtrSafe Function CloseHandle Lib "kernel32" (ByVal hObject As LongPtr) As Long Private Declare PtrSafe Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn As LongPtr, ByVal hmod As LongPtr, ByVal dwThreadId As Long) As LongPtr Private Declare PtrSafe Function CallNextHookEx Lib "user32" (ByVal hHook As LongPtr, ByVal ncode As Long, ByVal wParam As LongPtr, lParam As LongPtr) As LongPtr Private Declare PtrSafe Function GetModuleHandle Lib "kernel32" Alias "GetModuleHandleA" (ByVal lpModuleName As String) As LongPtr Private Declare PtrSafe Function UnhookWindowsHookEx Lib "user32" (ByVal hHook As LongPtr) As Long Private Declare PtrSafe Function SendDlgItemMessage Lib "user32" Alias "SendDlgItemMessageA" (ByVal hDlg As LongPtr, ByVal nIDDlgItem As Long, ByVal wMsg As Long, ByVal wParam As LongPtr, ByVal lParam As LongPtr) As LongPtr Private Declare PtrSafe Function GetClassName Lib "user32" Alias "GetClassNameA" (ByVal hWnd As LongPtr, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long Private Declare PtrSafe Function GetCurrentThreadId Lib "kernel32" () As Long   Yo prefiero usar Public, pero lo dejo en Private como te lo han mostrado. Saludos.
    • Estiamados foristas, acudo a Uds para encontrar ayuda al siguiente tema. Tengo una matriz en power bi en la que coloque el ID de una tabla producto y 3 medidas: 1er fecha 2da fecha Dias entre fechas Lo que necesito encontrar es que me traiga una nueva medida en que los dias entre fechas sea >= a 365 dias Trate de hacerlo con un CALCULATE -  ALL - FILTER pero o no me toma argumentos booleanos o no me toma la medida de dias entre fechas ya que no es una columna no esta en la tabla origen (es una medida calculada) Les paso en excel el ejemplo Dede ya muchas gracias data.xlsx
    • Hola Gerson Muchas gracias por tus archivos. No tengo Office 365 por lo que el primer archivo no lo puede utilizar. El segundo funciona perfectamente pero si intento crear más columnas me aparece error. El tercero no lo entiendo porque no veo ninguna fórmula en la tabla resumen. ¿Me puedes explicar el significado de lo que he marcado en verde? =SI(FILAS($A$1:$A1)>$B$12;"";INDICE(data!$A$10:$F$29;AGREGAR(15;6;FILA(data!$A$10:$A$29)-9/((data!$A$10:$A$29>=$C$7)*(data!$A$10:$A$29<=$C$8));FILAS($A$1:$A1));COLUMNAS($A$1:A$1))) Muchas gracias de nuevo Gerson. Saludos 
    • 😅😊   En la celda E10 debes escribir o seleccionar de alguna lista,  el mes que deseas traer, por ejm Ago en F10:   =INDICE(Hoja1!C10:N10,COINCIDIR(E10,Hoja1!C2:N2,))   //----------- 🙄 O si lo que quieres es traer el dato del mes actual =INDICE(Hoja1!C10:N10,MES(HOY()))   Mi separador de argumentos es la coma, si el tuyo es otro, corriges.   saludos, 😀 Silvia
  • Recently Browsing

    No registered users viewing this page.

×
×
  • Create New...

Important Information

Privacy Policy