Jump to content

Adaptar código macro de una planilla a otra


Recommended Posts

Posted

Estimados necesitaba hacer una función que entregue un valor de acuerdo a dos celdas y que luego de tener ese valor, en otra celda, busque en una columna si se repite el numero de una celda, después si se repite utilizar los valores de las columnas aledañas a las celdas en donde se encontraron igualdades para hacer un calculo de precio según el valor de estas.

Primero estuve tratando sin macros pero no se me ocurrió como. Después me ayudaron con esta macro que realiza el calculo en una planilla pequeña, ahora cuando intente realizarlo en la planilla real no pude. Adjunto planilla Ejemplo y planilla Real con la macro no funcionando.

Este es el macro que funciona en la planilla de ejemplo son 2 modulos...

Modulo 1

Option Explicit

Option Base 1

Function BUSCARV2(valor1, valor2, area As Range, columna As Integer)

'Stop

'Este proceso crea una funcion personalizada en la cual busca dos valores

Dim i As Long

Dim resultado As Variant

Dim dim1 As Integer

Dim dim2 As Integer

'dim1 guarda la cantidad de filas del area

dim1 = area.Rows.Count

'dim2 guarda la cantidad de columnas del area

dim2 = area.Columns.Count

For i = 1 To dim1

If area.Cells(i, 1).Value = valor1 Then

If area.Cells(i, 2).Value = valor2 Then

resultado = area.Cells(i, columna).Value

Exit For

End If

End If

Next i

BUSCARV2 = resultado

End Function

Function BUSCARV3(TRA As String, CAMION As Integer, qvale As Double) As Double

Stop

'Dim qvale As Double

Dim filas As Long

'qvale = Val(ActiveCell.Offset(0, -1))

Dim mD, d, SumPeso As Double

'filas = Application.WorksheetFunction.CountA("A1:A65000")

'mD = Range("A1:E1").Offset(filas, 0)

mD = Range("A2").CurrentRegion

For d = 2 To UBound(mD, 1)

If mD(d, 3) = TRA And _

mD(d, 4) = CAMION And _

mD(d, 5) = qvale Then

SumPeso = SumPeso + mD(d, 1)

End If

Next

BUSCARV3 = mD(d, 1) * qvale / SumPeso

End Function

Sub BUSCARxPRECIO()

Dim TRA As String, CAMION As Integer, qvale As Double

TRA = ActiveCell.Offset(0, -3)

CAMION = ActiveCell.Offset(0, -2)

qvale = ActiveCell.Offset(0, -1)

Dim mD, d, SumPeso As Double

mD = Range("A1").CurrentRegion

For d = 2 To UBound(mD, 1)

If mD(d, 3) = TRA And _

mD(d, 4) = CAMION And _

mD(d, 5) = qvale Then

SumPeso = SumPeso + mD(d, 1)

End If

Next

'BUSCARV3 = mD(d, 1) * qVALE / SumPeso

End Sub

Modulo 2

Option Explicit

Option Base 1

Sub BUSCARxVALOR()

Dim f

f = Application.WorksheetFunction.CountA(Range("E:E")) + 1

Range("AA:AX").ClearContents

Range("E2:F" & f).ClearContents

Dim mP

Dim p

Dim mX

Dim mS

Dim s

Dim v1

Dim v2

mP = Sheets("PROVEEDORES").Range("A1").CurrentRegion

mS = Sheets("SERVICIOS").Range("A1").CurrentRegion

mX = Sheets("SERVICIOS").Range("A1").CurrentRegion

For s = 2 To UBound(mS, 1)

For p = 1 To UBound(mP, 1)

If mS(s, 3) = mP(p, 1) And _

mS(s, 4) = mP(p, 2) Then

mS(s, 5) = mP(p, 3)

Exit For

End If

Next

Next

Range("A1").Resize(s - 1, 5) = mS

'Stop

ORDENAR

Application.ScreenUpdating = False

VALORESxUNICOS

IMPORTES

Range("AA:AX").ClearContents

Application.ScreenUpdating = True

End Sub

Sub IMPORTES()

Dim mS

Dim s

Dim abc

Dim mI, i

mS = Sheets("SERVICIOS").Range("A1").CurrentRegion

mI = Range("AA1").CurrentRegion

'ReDim Preserve mS(s, 6)

For s = 2 To UBound(mS, 1)

abc = mS(s, 2) & "_" & mS(s, 3) & "_" & mS(s, 4)

For i = 2 To UBound(mI, 1)

If abc = mI(i, 1) Then

'Stop

mS(s, 5) = mI(i, 3)

mS(s, 6) = mS(s, 1) * mI(i, 4)

Exit For

End If

Next

Next

Range("A1").Resize(s - 1, 6) = mS

End Sub

Sub VALORESxUNICOS()

Dim mS

Dim s

Dim abc As String, f As Long, r As Range

mS = Sheets("SERVICIOS").Range("A1").CurrentRegion

f = 1

abc = mS(f, 2) & "_" & mS(f, 3) & "_" & mS(f, 4)

Range("AA" & f) = abc

Range("AB" & f) = mS(f, 1)

Range("AC" & f) = mS(f, 5)

Range("AD" & f) = "Valor#"

For s = 2 To UBound(mS, 1)

abc = mS(s, 2) & "_" & mS(s, 3) & "_" & mS(s, 4)

On Error Resume Next

If Range("AA" & f) = abc Then

'Range("AB" & s - 1) = Range("AB" & s - 1) + mS(s, 5)

'n_a_d_a

Range("AB" & f) = mS(s, 1) + Range("AB" & f)

Else

f = f + 1

Range("AA" & f) = mS(s, 2) & "_" & mS(s, 3) & "_" & mS(s, 4)

Range("AB" & f) = mS(s, 1)

Range("AC" & f) = mS(s, 5)

End If

Next

'Stop

Set r = Range("AA1")

f = 0

Do

f = f + 1

If r.Offset(f, 0) = "" Then Exit Do

r.Offset(f, 3) = r.Offset(f, 2) / r.Offset(f, 1)

Loop

End Sub

Sub ORDENAR()

Dim f

f = Application.WorksheetFunction.CountA(Range("A:A"))

ActiveWorkbook.Worksheets("SERVICIOS").Sort.SortFields.Clear

ActiveWorkbook.Worksheets("SERVICIOS").Sort.SortFields.Add Key:=Range("B2:B" & f _

), SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal

ActiveWorkbook.Worksheets("SERVICIOS").Sort.SortFields.Add Key:=Range("C2:C" & f _

), SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal

ActiveWorkbook.Worksheets("SERVICIOS").Sort.SortFields.Add Key:=Range("D2:D" & f _

), SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortNormal

With ActiveWorkbook.Worksheets("SERVICIOS").Sort

.SetRange Range("A1:F" & f)

.Header = xlYes

.MatchCase = False

.Orientation = xlTopToBottom

.SortMethod = xlPinYin

.Apply

End With

End Sub

Gracias Saludos

Planilla Real.xls

Ejemplo.xls

Archived

This topic is now archived and is closed to further replies.

  • 108 ¿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
  • Files

  • Download Statistics

    • Files
      184
    • Comments
      96
    • Reviews
      28

    More information about "Un juego solitario en Excel"
    Latest File
    By pegones1

    4    0

  • Crear macros Excel

  • Posts

    • Hola. Tu archivo no tiene macros. Sobre las celdas combinadas, ya que no puedes evitar su uso al no ser tus archivos, lo mejor es "des combinarlas" previo a cualquier cosa, incluso en tu misma macro (que no envías). 
    • Hola buenas tardes tengo un archivo en excel que copia varias tablas y las importa a word de manera automatica. Este selecciona las tablas en base a las filas con datos de mi columna C. pueden ser  diferentes rango de tablas. (Pero siempre mi rango es de celdas continuas y con valores continuas) Funciona muy bien. El problema que ahora tengo es que muchos archivos con tablas  tienen las celdas combinadas ya sea horizontalmento o vertical. Aqui es donde empieza mi problema ya que son formatos de origen no puedo modificarlas. Quisiera ajustar mi macro en la parte de seleccion de rango de tablas y que pueda considerar la celdas combinadas y pegarlos en word sin problema. Ya que actualmente no me pone algunas tablas o rangos, o me repite las tablas y no considera las demas. Todo esto a que en algunas no hay valores o las celdas estan combinadas.   Muchas gracias Seleccion automatica de celdas combis.xlsx
    • por si te sirve: la primera matriz (pivotarpor) al inicio los que no tienen profesor asignado (orden ascendente por omision) la segunda (2 matrices y solo unicos) en el orden de aparicion (no asignados al final) la tercera (2 matrices) omite los no asignados (tambien por orden de aparicion) unicos y suma (ayudaExcel).xlsx
    • No se si este tema va aquí, si no es así, pido disculpas. Llevo varios días dando vueltas a un fallo que me sale al exportar una tabla a xml y que no consigo resolver. El fallo que me da es que no las asignaciones no son exportables y al comprobar la asignación me dice datos no normalizados.     Libro1.xlsx
    • Buenas tardes estimado JSDJSD, muchas gracias por responder. En efecto esta parte quedo perfecta. Pero me falto indicar que la macro se ejecute dependiendo de la celda L1 ( Caliza o Mezcla). Entonces si dice Caliza aplica la macro que me enviaste, pero si dice Mezcla que haga lo siguiente: Busque el  ultimo dato de la columna K de la hoja Mezcla Adición del libro Base de datos Cementos producido 2024, con la condición de que la columna B debe ser igual a 4 y el dato lo coloque en la celda N1 de la hoja Cemento del libro Cemento. Te comento que el libro Prehomo y Base de datos Cementos producidos 2024 están en carpetas diferentes ya que estos los maneja otra área, como se enmendaría este caso por el comentarios que me enviaste de la ruta. Saludos y un fuerte abrazo   Cemento-2.xlsm
  • Recently Browsing

    • No registered users viewing this page.
×
×
  • Create New...

Important Information

Privacy Policy