Jump to content

Guardar datos en una hoja específica para registrar todos los datos.


francis75

Recommended Posts

Posted

Hola despues de mirar muchos códigos por el foro he conseguido uno que me va a valer para partir al resultado que pretendo.

Espero que poco a poco puedan ayudarme a confeccionar la macro.

La macro la funcionalidad que tiene es que al pulsar en Guardar se copian los datos a la hoja Registro, lo que pretendo es que si vuelvo a pulsar en Guardar se actualicen dichos datos si éstos ya existen, pero ahora si pulso se me copia la fila 21 en la fila 1 de la hoja Registro, pulsen y vean, y no entiendo el porqué.

Aquí os pongo la macro tal cual la tengo ahora:

Sub Guardar()
Dim hoja As Object
Dim archivo As String
Dim hojaDestino As Object
Dim existe
Dim xFil As Long


On Error Resume Next
Application.ScreenUpdating = False
Set hoja = ActiveSheet
archivo = Range("C3")
Set hojaDestino = Sheets("Registro")
Set existe = hojaDestino.Columns("A:A").Find(archivo)


With hojaDestino
If existe = "" Then xFil = .Range("A" & Rows.Count).End(xlUp)(2).Row
If existe <> "" Then existe = existe
With .Range("A" & xFil)
.Value = hoja.Range("C3")
.NumberFormat = "000000"
End With
.Range("B" & xFil) = hoja.Range("C5")
.Range("C" & xFil) = hoja.Range("F5")
.Range("D" & xFil) = hoja.Range("C7")
.Range("E" & xFil) = hoja.Range("C9")
.Range("F" & xFil) = hoja.Range("C11")
With .Range("A" & xFil + 1)
.Value = hoja.Range("C3")
.NumberFormat = "000000"
End With
With .Range("C" & xFil + 1)
.Value = hoja.Range("A21")
.NumberFormat = "dd/mm/yy"
End With
.Range("D" & xFil + 1) = hoja.Range("B21")
.Range("E" & xFil + 1) = hoja.Range("C21")
.Range("F" & xFil + 1) = hoja.Range("D21")
If existe <> "" Then existe = existe + 1
End With
Set existe = Nothing
Set hojaDestino = Nothing
Set libro = Nothing
End Sub[/CODE]

Si por favor me pueden ayudar se lo agradecería.

Saludos.

Registro2.zip

Posted

Hola de nuevo,

Con respecto con la consulta anterior he conseguido solventar el problema, aquí está la macro:

Option ExplicitSub Guardar()
Dim Id As String
Dim hoja As Object
Dim hojaDestino As Object
Dim xFil As Long
Dim existe
On Error Resume Next
Application.ScreenUpdating = False
Id = Range("C3")
Set hoja = ActiveSheet
Set hojaDestino = Sheets("Registro")
existe = Application.WorksheetFunction.Match(Id, hojaDestino.Columns("A:A"), 0)
With hojaDestino
If existe = "" Then xFil = .Range("A" & Rows.Count).End(xlUp)(2).Row
If existe <> "" Then xFil = existe
.Range("A" & xFil) = hoja.Range("C3")
.Range("B" & xFil) = hoja.Range("C5")
.Range("C" & xFil) = hoja.Range("F5")
.Range("D" & xFil) = hoja.Range("C7")
.Range("E" & xFil) = hoja.Range("C9")
.Range("F" & xFil) = hoja.Range("C11")

.Range("A" & xFil + 1) = hoja.Range("C3")
With .Range("C" & xFil + 1)
.Value = hoja.Range("A21")
.NumberFormat = "dd/mm/yy"
End With
'.Range("C" & xFil + 1) = hoja.Range("A21")
.Range("D" & xFil + 1) = hoja.Range("B21")
.Range("E" & xFil + 1) = hoja.Range("C21")
.Range("F" & xFil + 1) = hoja.Range("D21")
If existe <> "" Then existe = existe + 1
End With
Set hojaDestino = Nothing
Application.ScreenUpdating = True
End Sub[/CODE]

aunque tengo un problema con la celda C3 y es que si coloco numeros la macro no me funciona como debiera, en cambio si pongo palabras como lo que está ahora "Op01" si funciona, ¿alguien sabe porque sucede?, alguna forma de solventarlo?

La otra cuestión, es que quiero que aparezca todo el recuadro.

[b]MUY IMPORTANTE:[/b] teniendo en cuenta que este cuadro puede tener 2 filas de datos como puede tener 50 filas de datos, [u]es variable[/u].

Lo he intentado con la función [b]For[/b] pero no he dado con la solución.

Subo el archivo donde detallo lo expuesto anteriormente,

Espero me podais ayudar, Saludos.

Registro3.zip

  • 3 weeks later...
Posted

Hola Francis75... revisa el codigo que te mando a ver si te sirve...

Option Explicit

Sub Guardar()

Dim J As Integer

Dim DATOS As Variant

Dim Id As String

Dim hoja As Object

Dim hojaDestino As Object

Dim xFil As Long

Dim existe

On Error Resume Next

Application.ScreenUpdating = False

Id = Range("C3")

Set hoja = ActiveSheet

Set hojaDestino = Sheets("Registro")

existe = Application.WorksheetFunction.Match(Id, hojaDestino.Columns("A:A"), 0)

With hojaDestino

If existe = "" Then xFil = .Range("A" & Rows.Count).End(xlUp)(2).Row

If existe <> "" Then xFil = existe

.Range("A" & xFil) = hoja.Range("C3")

.Range("B" & xFil) = hoja.Range("C5")

.Range("C" & xFil) = hoja.Range("F5")

.Range("D" & xFil) = hoja.Range("C7")

.Range("E" & xFil) = hoja.Range("C9")

.Range("F" & xFil) = hoja.Range("C11")

With .Range("C" & xFil + 1)

.NumberFormat = "dd/mm/yy"

End With

DATOS = Application.WorksheetFunction.Count(Range("a21:a65536"))

For J = 1 To DATOS

With hojaDestino

.Range("A" & xFil + J) = hoja.Cells(3, 3)

.Range("C" & xFil + J) = hoja.Cells(20 + J, 1)

With .Range("C" & xFil + J)

.NumberFormat = "dd/mm/yy"

End With

.Range("D" & xFil + J) = hoja.Cells(20 + J, 2)

.Range("E" & xFil + J) = hoja.Cells(20 + J, 3)

.Range("F" & xFil + J) = hoja.Cells(20 + J, 4)

End With

Next J

'.Range("A" & xFil + 1) = hoja.Range("C3")

'.Range("C" & xFil + 1) = hoja.Range("A21")

' .Range("D" & xFil + 1) = hoja.Range("B21")

' .Range("E" & xFil + 1) = hoja.Range("C21")

' .Range("F" & xFil + 1) = hoja.Range("D21")

If existe <> "" Then existe = existe + 1

End With

Set hojaDestino = Nothing

Application.ScreenUpdating = True

End Sub

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

  • Current Donation Goals

    • Raised 0.00 EUR of 130.00 EUR target
  • 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