Macro en Excel que busque, corte y pegue
Necesito una macro que busque en la hoja “2016” filas que contengan un registro que se llame “Accomodation, Regular”, corte todas las filas en las que aparezca y las pegue en una hoja que se llame Accomodation, Regular del mismo libro y debajo del la fila que contiene los títulos.
1 Respuesta
.
Buenas, Francisco
La siguiente rutina hace lo que solicitas, utilizando los filtros avanzados de MS Excel.
Para que funcione, necesitas colocar los titulos de las columnas de la base original que necesitas que aparezcan en la hoja Accomodation, Regular. Si fueran todos, copia la linea de la base original y pegala en la hoja mencionada. Es decir, puedes extraer todos los campos de la base original o solo aquellos que te interese.
Luego, y esto es fundamental, elige un rango libre de dos lineas y una columna en la hoja de destino donde colocar el criterio de extracción, por ejemplo BB1:BB2
En la primera celda de esas dos coloca el mismo título de la columna donde esté el dato clave y abajo el criterio: “Accomodation, Regular”
Algo así como esto:
Luego, accede al Editor de VBA (Atajo: Alt + F11), inserta un módulo - si no tuvieras uno ya- y pega el siguiente código:
Sub SacaLineas() '---- Variables modificables: '=== FRANCISCO, modifica estos datos de acuerdo a tu proyecto: HojaOrig = "2016" HojaDest = "Accomodation,Regular" CritAreaH = "BB1:BB2" 'rango donde se coloca el criterio de extracción SourceAreaH = "A12:CY14000" ' rango base de datos de origen OutpAreaH = "A13:BH13" ' fila de títulos en hoja de destino '---- fin Variables ' '---- inicio de rutina: ' Sheets(HojaDest).Select Sheets(HojaOrig).Range(SourceAreaH).AdvancedFilter Action:=xlFilterCopy, CriteriaRange:=Range(CritAreaH), _ CopyToRange:=Range(OutpAreaH), Unique:=False End Sub
Veras al inicio del código unas variables que deberás adaptar a los rangos propios de tu libro.
Como verás, esta forma flexibiliza lo que quieras extraer, simplemente cambiando el criterio en el rango que indicaste.
.
Hola Fernando,
Muchas gracias por tu respuesta y avisarte que mis conocimientos sobre VBA son mas bien escasos. He hecho lo que he entendido en tu respuesta pero me da un error de compilación.
Sería posible mandarte la hoja y que la vieras?
Muchísimas gracias y un abrazo desde Madrid
Francisco J. García
.
Buenas, Francisco
Donde te marca el error es porque escribiste el nombre de la hoja sin comillas. En realidad, alli debería ir el nombre de la variable HojaDest (sin comillas) que ya tiene cargado el nombre de la hoja de destino. Otro tanto pasa con la hoja de origen y con las otras variables.
No deberías haber reemplazado los nombres de las variables en la instrucción.
Deberías haber pegado la rutina tal como te la envié y, eventualmente, cambiar los rangos en el sector de variables que te dejé debidamente delimitado.
Es decir, los datos que deberías modificar son los que están despues del signo igual en estas variables:
CritAreaH = "BB1:BB2" 'rango donde se coloca el criterio de extracción
SourceAreaH = "A12:CY14000" ' rango base de datos de origen
OutpAreaH = "A13:BH13" ' fila de títulos en hoja de destino
Respetando, claro está, el comillado que tienen
Prueba con estas indicaciones y dime si anduvo.
Saludos
Fer
.
Hola Fernando,
no me ha funcionado. Dejando la macro original me da el siguiente error
Siento mucho molestarte tanto.
Saludos
.
Ok, Francisco
El mensaje de error ahora es otro, porque la sintaxis de la rutina es correcta.
Faltaría que me confirmes si los rangos que yo indiqué coinciden con los tuyos (poco probable)
Deberías colocar en cada caso los reales de tu planilla o comentame qué rango ocupa la base, a qué rango debería extraer los datos y finalmente, si el rango de criterios es el mismo que indiqué o lo pusiste en otra ubicación.
Con esos datos podremos corregir la rutina.
Un abrazo
Fer
.
Hola Fernando
Te comento:
CritAreaH = "Q1:Q2" 'rango donde se coloca el criterio de extracción
Entiendo que aquí debo poner la columna donde se va a poner lo que se extrae de la hoja original.
SourceAreaH = "B1:BP5000" ' rango base de datos de origen
Aquí pongo el rango de donde se va a extraer los datos en la hoja original
OutpAreaH = "A1:BP1" ' fila de títulos en hoja de destino
Aquí pongo la fila que contiene los títulos de la hoja de destino
Ejecuto y me da el siguiente error
Agradecerte las molestias que te tomas.
Saludos
.
Buenas, Francisco
Estás muy cerca de lograrlo.
Fíjate que el área de la base de datos empieza en la columna B (hasta BP), mientras que la de extracción comienza en la columna A (hasta BP), por lo que tienes una columna más que la rutina no sabe qué hacer con ella.
Entonces, ajusta ambos rangos para que coincidan.
Recuerda que, en el área donde quieres que te deje los datos debe contener los títulos de campo IGUAL a como están escritos en la base de datos original. Pueden ser todos o algunos, o duplicados, o en cualquier orden, pero todas las celdas deben tener su encabezado para que no te salga un error como el que muestra la imagen que pasaste.
Creo que ya lograras tu objetivo siguiendo las instrucciones que te compartí.
Un abrazo
Fer
.
Hola Fernando,
Ya hemos conseguido que no dé ningún error
Pero la macro no hace lo que necesito.
Necesitaría que cuando se ejecute la macro:
- que corte todas las filas de la hoja "2016" que contengan "Accomodation, Regular"
-pegue toda la fila en la hoja que se llama "Accomodation, Regular" (la cual tiene los mismos títulos)
-borre todas las filas de la hoja "2016" que hayan quedado en blanco.
-y que cuando vuelva a poner nuevos registros en la hoja "2016" y ejecute nuevamente la macro los incremente en la hoja "Accomodation, Regular".
Quiero agradecerte la ayuda que me estás prestando y disculparme por el trabajo que te estoy dando.
Muchas gracias y saludos
Francisco
.
Hola, Francisco
Si bien los filtros avanzado permiten, además de extractar en otro lugar, filtrar en la misma base -lo que permitiría eliminar las lineas que cumplan con el criterio- se complica mantener lo que hayas extractado antes porque la nueva consulta pisaría lo anterior.
Por lo tanto, estamos frente a otro animal. La rutina para hacer lo que quieres será distinta a la que te compartí originalmente. De allí la demora en responderte.
Ya no será necesaria el área de criterios y el registro a buscar lo indicarás dentro del siguiente código:
Sub SacaLineas() '---- Variables modificables ---- '=== FRANCISCO, modifica estos datos de acuerdo a tu proyecto: HojaOrig = "2016" 'hoja donde está la base original Buscar = "Accomodation,Regular" 'texto a buscar HojaDest = "Accomodation,Regular" ' Hoja donde dejar las lineas TitDestino = "A13:BH13" ' fila de títulos en hoja de destino '---- fin Variables ' '---- inicio de rutina: ' UltFila = Sheets(HojaDest).Range(Left(TitDestino, 1) & Rows.Count).End(xlUp).Row cont = 0 Sheets(HojaOrig).Select Do On Error Resume Next Encontrado = Cells.Find(What:=Buscar, LookAt:=xlWhole).Row If Err.Number = 0 And Len(Encontrado) > 0 Then Range("A" & Encontrado).EntireRow.Copy Sheets(HojaDest).Range(Left(TitDestino, 1) & UltFila + 1).PasteSpecial Paste:=xlPasteValues Sheets(HojaDest).Range(Left(TitDestino, 1) & UltFila + 1).PasteSpecial Paste:=xlPasteFormats Application.CutCopyMode = False Range("A" & Encontrado).EntireRow.Delete cont = cont + 1 UltFila = UltFila + 1 Else GoTo TheEnd End If Loop While Len(Encontrado) > 0 TheEnd: Err.Clear On Error GoTo 0 ElMensaje = IIf(cont = 0, "NO SE TRASLADO LINEA ALGUNA, porque" & Chr(10) & "no se encontró " & Buscar & " en la hoja " & HojaOrig, "Se transfirieron: " & cont & " linea" & IIf(cont > 1, "s", "") & Chr(10) & "a la hoja " & HojaDest) TipoMens = IIf(cont = 0, vbCritical, vbInformation) ElTitulo = IIf(cont = 0, "NO SE HIZO NADA", "TERMINADO!") Application.ScreenUpdating = True MsgBox ElMensaje, TipoMens, ElTitulo End Sub
Espero que ahora sí quedes satisfecho.
Un abrazo
Fer
.
Buenos días Fer
!Fantástico, ha funcionado perfectamente.
Te agradezco muchísimo las molestias que te has tomado para ayudarme.
Ahora me queda mucho trabajo por delante para desarrollar esta hoja, pero espero contar con tu inestimable si me vuelvo a ver atascado.
Muchas gracias y un fuerte abrazo.
Francisco
Hola Fer,
Vuelvo a necesitar de tus conocimientos, creo que esta es más fácil que la anterior aunque no es de macro sino de fórmulas.
Necesito que se active un hipervínculo que hay en una celda, cuando en otra celda dé un valor "Correcto"
Como siempre muchas gracias y un abrazo
Francisco
.
En el mensaje de mi perfil había colocado que estaría de vacaciones hasta hoy, de allí la demora en responderte.
En otra época hubiese sido necesario una rutina de VBA, pero hoy puedes usar una fórmula como esta para crear un hipervínculo:
=HIPERVINCULO("[Archivo.xlsx]'Hoja1'!B14";"Click aqui")
[Considera si usas comas o punto y coma para separar argumentos de las funciones. Yo usé ";"]
Desde luego, deberás reemplazar el nombre del archivo, hoja y celda donde quieres que te lleve esa celda.
Entonces sólo falta anidar esa función con un condicional para que se active cuando encuentre "Correcto" en otra celda, supongamos F2. Entonces tu fórmula final sería:
=SI($F$2="Correcto";HIPERVINCULO("[Archivo.xlsx]'Hoja1'!B14";"Click aqui");"")
Un abrazo
Fer
.
Hola Fer,
Espero que hayas disfrutado de tus vacaciones.
Si ha funcionado la fórmula, pero no me explicado lo suficiente.
Lo que intento es que cuando se de la condición de "correcto" se ejecute un sonido que esta enlazado mediante un hipervínculo.
La fórmula :
=SI($D$2="Correcto";HIPERVINCULO("[Audios\Scared.mp3]"))
No se ejecuta si no hago click en la casilla donde reside la fórmula y esta "Correcto" a la celda que hace referencia.
¿Seria posible que se ejecutara el sonido automáticamente cuando D2 estuviera correcto?
Muchas gracias por tus indicaciones.
Un abrazo
.
Buenas, Francisco
Efectivamente, esa aclaración cambia radicalmente la pregunta (de hecho, a esta altura ya deberías haber abierto otra, porque se están mezclando temas).
Entonces sí necesitarás una rutina de Visual Basic que asociaremos al evento de que cambie el contenido de la celda D2. Además será necesaria una función API que se declara al inicio para poder reproducir achivos WAV (solamente).
Para que funcione, activa el editor de Visual Basic (presiona Alt+F11) y en el panel de la izquierda busca la hoja donde quieres que esto ocurra. Da doble click sobre ella. (Otra forma de llegar a este punto es hacer click derecho sobre la solapa de esta hoja y elegir la opción "Ver Código)
Allí pega el siguiente código:
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ (ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== LUIS, modificá estos datos de acuerdo a tu proyecto: CeldaCtrl = "$D2" Clave = "Correcto" CarpetaSon = "C:\Audios" CarpetaSon = "C:\Windows\Media" 'elimina esta linea para usar la variable de la fila anterior ArchivoSon = "Scared.mp3" ' <<<< debe ser .wav !!!! ArchivoSon = "Chimes.wav" 'elimina esta linea para usar la variable de la fila anterior '---- fin Variables ' '---- inicio de rutina: ' ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon If Target.Address(False, False) = CeldaCtrl And Range(CeldaCtrl).Value = Clave Then Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End Sub
Espero que sea lo que buscas.
Un abrazo
Fer
.
Hola Fer,
siento mucho abusar de tu confianza, pero soy consciente de la limitación de mis conocimientos informáticos y, a veces creo que las cosas se pueden hacer de manera sencilla y personas como tu, me demuestran lo equivocado que estoy.
No estoy seguro de haber modificado correctamente el código que me mandas,
Entiendo que la CarpetaSon es donde están los archivos wav que quiero que se ejecuten cuando en la casilla D2 (tengo esta formula =SI(B2=C2;"Correcto";"Incorrecto")) aparezca Correcto.
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ (ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== LUIS, modificá estos datos de acuerdo a tu proyecto: CeldaCtrl = "$D2" Clave = "Correcto" CarpetaSon = "G:\Inglés\Excell\Audios" ArchivoSon = "Scared.wav" ' <<<< debe ser .wav !!!! '---- fin Variables ' '---- inicio de rutina: ' ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon If Target.Address(False, False) = CeldaCtrl And Range(CeldaCtrl).Value = Clave Then Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End Sub
Siento que por mi desconocimiento se este alargando mucho esta pregunta
Muchas gracias y un abrazo
.
Hola, Francisco
La rutina que te envié está atada a que se produzca un cambio físico en determinada celda.
Veo en tu caso que D2 tiene una fórmula por lo que cambiará el resultado pero no lo que tiene dentro (la fórmula es la misma).
Por tanto, asociaremos la rutina a las celdas que sí cambian B2 y C2, asumiendo que estas no sean, a su vez, otras celdas con fórmulas.
Sustituye todo lo que había en aquel panel de VBA por el siguiente:
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ (ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== FRANCISCO, modificá estos datos de acuerdo a tu proyecto: ' CeldaCambio1 = "B2" 'celda que se modifica CeldaCambio2 = "C2" 'celda que se modifica ' CeldaCtrl = "D2" 'Celda con fórmula Clave = "Correcto" CarpetaSon = "G:\Inglés\Excell\Audios" ArchivoSon = "Scared.wav" ' <<<< debe ser .wav !!!! '---- fin Variables ' '---- inicio de rutina: ' ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon If Target.Address(False, False) = UCase(CeldaCambio1) Or Target.Address(False, False) = UCase(CeldaCambio2) Then ActiveSheet.Calculate If Range(CeldaCtrl).Value = Clave Then Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End If End Sub
Desde luego, asegúrate de que el archivo de sonido sea, realmente, WAV (supongo que no le habrás cambiado la extensión solamente).
Respecto a la extensión de la pregunta, no tengo ningún problema en seguir hasta que esté agotado el tema. Es sólo que empezó como "Macro en Excel que busque, corte y pegue" y ahora estamos viendo cómo producir un sonido condicionalmente. Son dos temas distintos y deberían haber sido dos preguntas distintas. En particular por si esto le sirviera a alguien más.
Simplemente, tenlo en cuenta para próximas preguntas.
Un abrazo
Fer
.
Hola Fer,
Ha funcionado perfectamente.
Pero necesito dar un paso más (espero que sea el definitivo), realmente es toda la columna "C" la que se modifica, al igual que es toda la columna "D" la que contiene las fórmulas y en ArchivoSon debería poner todos los WAV pero no se la forma de ponerlos (quizás así "Scared.wav" "Not Yet")
La intención del excel es enseñar a niños palabras en inglés básico y cuando acierten que se reproduzca el sonido.
Muchas gracias y un fuerte abrazo
Francisco
.
Ok, eso cambia las cosas... Pero no mucho
Por lo que veo sólo se ingresan datos en la columna C y oculto, en la columna, B está el dato correcto.
Entonces la siguiente variante controla cualquier ingreso en la columna C y evalua la fórmula de columna D correspondiente a la celda donde se ingresó el ultimo dato:
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ (ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== FRANCISCO, modificá estos datos de acuerdo a tu proyecto: ' ColCambio = "C" 'celda que se modifica ColCtrl = "D" 'Celda con fórmula Clave = "Correcto" CarpetaSon = "G:\Inglés\Excell\Audios" ArchivoSon = "Scared.wav" ' <<<< debe ser .wav !!!! '---- fin Variables ' '---- inicio de rutina: ' ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon If Target.Column = Range(UCase(ColCambio) & "1").Column Then ActiveSheet.Calculate If Range(UCase(ColCambio) & Target.Row).Value = Clave Then Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End If End Sub
Imagino que estará OK con ese cambio.
Abrazo
Fer
.
Hola Fer,
Ahora no reproduce el sonido de la primera fila que se llama "Scared.wav"
Entiendo que en ArchivoSon deberían ir todos los ficheros wav, pero ¿como los debería escribir (quizás así "Scared.wav" "Not Yet")?
Saludos
Francisco
.
Buen día, Francisco
Me parece que recién estoy entendiendo -porque no lo mencionaste antes- que tienes varios nombres de archivo -no solo scared.wav- en alguna parte de tu planilla. Es decir uno por cada expresión a traducir.
Suponiendo que los tuvieras en la columna E (que noto oculta), esta rutina traerá el nombre de ese archivo y lo hará sonar:
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ (ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== FRANCISCO, modificá estos datos de acuerdo a tu proyecto: ' ColCambio = "C" 'Columna que se modifica ColCtrl = "D" 'columna con fórmula de Control ColArchSon = "E" 'columna con Nombre archivo de Sonido Clave = "Correcto" CarpetaSon = "G:\Inglés\Excell\Audios" '---- fin Variables ' '---- inicio de rutina: ' If Target.Column = Range(UCase(ColCambio) & "1").Column Then ActiveSheet.Calculate If Range(UCase(ColCambio) & Target.Row).Value = Clave Then ArchivoSon = Range(UCase(ColArchSon) & Target.Row).Value & ".wav" ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End If End If End Sub
Ten en cuenta que ese sea el nombre exacto del archivo de sonido. En las pruebas que hice, costó que reconozca algunos wav que tenían nombres con espacios. Internamente, creo, los maneja con otro nombre.
Saludos
Fer
.
Hola Fer,
Lamentablemente no ha funcionado, con esta rutina ni siquiera a funcionado con el primer sonido (scared.wav).
Efectivamente en la columna "E" están los hipervínculos a los sonidos wav.
Siento mucho todo el trabajo que te estoy dando.
Un abrazo
.
Buenas, Francisco
NO necesitas hipervínculos a los archivos de sonido, funciona con el nombre del archivo. La extensión .wav también se la agrega la rutina
Entonces, en la columna E coloca solo el nombre del archivo a ejecutar.
Saludos
Fer
.
Hola Fer
he quitado los hipervínculos y sigue sin funcionar.
¿que crees que puede suceder?
Un abrazo
Francisco
.
Buenas, Francisco
Más cerca.
En el mensaje anterior te había indicado: coloca solo el nombre del archivo a ejecutar
Veo que lo dejaste con la extensión, entonces, como la rutina también la agrega, se duplica
Imagino que con esto ya lo deberías lograr.
Saludos
Fer
.
.
Es curioso que alguna vez haya funcionado y ahora no.
Revisé, y no encuentro problema con la rutina en sí. Me inclino a pensar que hay algo con esos archivos.
Imagino que habrás controlado que los archivos están efectivamente en la carpeta G:\Inglés\Excell\Audios, que los archivos sean .wav reales (no basta con cambiarle la extensión al archivo).
Saludos
Fer
.
Edite el archivo mp3 y lo guarde en wav.
La única rutina que funciono fue esta pero solo para una única celda
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ (ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== FRANCISCO, modificá estos datos de acuerdo a tu proyecto: ' CeldaCambio1 = "B2" 'celda que se modifica CeldaCambio2 = "C2" 'celda que se modifica ' CeldaCtrl = "D2" 'Celda con fórmula Clave = "Correcto" CarpetaSon = "G:\Inglés\Excell\Audios" ArchivoSon = "Scared.wav" ' <<<< debe ser .wav !!!! '---- fin Variables ' '---- inicio de rutina: ' ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon If Target.Address(False, False) = UCase(CeldaCambio1) Or Target.Address(False, False) = UCase(CeldaCambio2) Then ActiveSheet.Calculate If Range(CeldaCtrl).Value = Clave Then Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End If End Sub
Siento darte tanto trabajo
Un abrazo
.
Ok, Francisco
Lo importante es que logres hacerlo funcionar.
Intenta con esta rutina. Como no tengo esos archivos le incluí una instrucción para que me muestre cada archivo que elije y lo hacía correctamente. En esta versión que te paso está anulada pero si te fallara, puedes activarla quitando el apostrofo.
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== FRANCISCO, modificá estos datos de acuerdo a tu proyecto: ' ColCambio = "C" 'Columna que se modifica ColCtrl = "D" 'columna con fórmula de Control ColArchSon = "E" 'columna con Nombre archivo de Sonido Clave = "Correcto" CarpetaSon = "G:\Inglés\Excell\Audios" '---- fin Variables ' '---- inicio de rutina: ' If Target.Column = Range(UCase(ColCambio) & "1").Column Then ActiveSheet.Calculate If Range(UCase(ColCtrl) & Target.Row).Value = Clave Then ArchivoSon = Range(UCase(ColArchSon) & Target.Row).Value & ".wav" ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon 'MsgBox ElSonido '< Control de nombre de archivo Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End If End If End Sub
Ahora sí debería funcionarte.
Abrazo
Fer
.
Hola Fer,
no ha funcionado y me da el siguiente error
No se cual es el apostrofo que hay que quitar
Un abrazo
Francisco
.
Buenas,
Primero pruébala así como está esta:
Private Declare Function PlaySound Lib "winmm.dll" Alias "PlaySoundA" _ (ByVal lpszName As String, ByVal hModule As Long, ByVal dwFlags As Long) As Long '---------------------------- Private Sub Worksheet_Change(ByVal Target As Range) '---- Variables modificables ---- '=== FRANCISCO, modificá estos datos de acuerdo a tu proyecto: ' ColCambio = "C" 'Columna que se modifica ColCtrl = "D" 'columna con fórmula de Control ColArchSon = "E" 'columna con Nombre archivo de Sonido Clave = "Correcto" CarpetaSon = "G:\Inglés\Excell\Audios" '---- fin Variables ' '---- inicio de rutina: ' If Target.Column = Range(UCase(ColCambio) & "1").Column Then ActiveSheet.Calculate If Range(UCase(ColCtrl) & Target.Row).Value = Clave Then ArchivoSon = Range(UCase(ColArchSon) & Target.Row).Value & ".wav" ElSonido = CarpetaSon & IIf(Right(CarpetaSon, 1) = "\", "", "\") & ArchivoSon 'MsgBox ElSonido '< Control de nombre de archivo Call PlaySound(ElSonido, &H1, &H1 Or &H20000) End If End If End Sub
Si todo funciona como pretendes, no tienes nada más que hacer.
En caso de que volvieras a tener inconveniente para obtener el sonido, vé a la línea:
'MsgBox ElSonido '< Control de nombre de archivo
Y borra el primer caracter (') para que, antes de intentar acceder al archivo de sonido, te muestre la dirección completa del archivo que quiere utilizar. Esto te servirá para verificar si hay algun error.
Abrazo
Fer
.
- Compartir respuesta