Código de Excel - Desglose Monetario

<<>>
sin imagen de perfil

Desglose Monetariográfica de visualizaciones


Excel

Publicado el 17 de Mayo del 2025 por Manuel
159 visualizaciones desde el 17 de Mayo del 2025
funcion donde seleccionas un rango de celdas que contienen cantidades y te entrega el desglose monetario, util para listas de raya, nominas, dispersion de efectivo

Requerimientos

esta hecho en VBA de excel 2021

1.0

Publicado el 17 de Mayo del 2025gráfica de visualizaciones de la versión: 1.0
159 visualizaciones desde el 17 de Mayo del 2025
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
Function DesgloseMonetarioRango(Rango As Range) As Variant
 
    Dim MonedasBilletes As Variant
    MonedasBilletes = Array(500, 200, 100, 50, 20, 10, 5, 2, 1, 0.5, 0.2, 0.1, 0.05, 0.02, 0.01)
    Dim DesgloseTotal As Object
    Set DesgloseTotal = CreateObject("Scripting.Dictionary")
    Dim Celda As Range
    Dim Cantidad As Double
    Dim i As Integer
    Dim CantidadRestante As Double
    Dim CantidadDeMonedas As Integer
    Dim Resultado As Variant
    Dim Fila As Integer
 
    ' Inicializar el diccionario de desglose total con todas las denominaciones en cero
    For i = LBound(MonedasBilletes) To UBound(MonedasBilletes)
        DesgloseTotal(MonedasBilletes(i)) = 0
    Next i
 
    ' Iterar a través de cada celda en el rango proporcionado
    For Each Celda In Rango
        If IsNumeric(Celda.Value) Then
            Cantidad = CDbl(Celda.Value)
            CantidadRestante = Cantidad
 
            ' Calcular el desglose para la cantidad actual y sumarlo al desglose total
            For i = LBound(MonedasBilletes) To UBound(MonedasBilletes)
                If CantidadRestante >= MonedasBilletes(i) Then
                    CantidadDeMonedas = Int(CantidadRestante / MonedasBilletes(i))
                    DesgloseTotal(MonedasBilletes(i)) = DesgloseTotal(MonedasBilletes(i)) + CantidadDeMonedas
                    CantidadRestante = CantidadRestante - (CantidadDeMonedas * MonedasBilletes(i))
                End If
            Next i
        End If
    Next Celda
 
    ' Crear la matriz de resultados con títulos y cantidades
    ReDim Resultado(1 To DesgloseTotal.Count, 1 To 2)
    Fila = 1
    For i = LBound(MonedasBilletes) To UBound(MonedasBilletes)
        Resultado(Fila, 1) = MonedasBilletes(i)
        Resultado(Fila, 2) = DesgloseTotal(MonedasBilletes(i))
        Fila = Fila + 1
    Next i
 
    DesgloseMonetarioRango = Resultado
 
End Function



Comentarios sobre la versión: 1.0 (0)


No hay comentarios
 

Comentar la versión: 1.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios...
CerrarCerrar
CerrarCerrar
Cerrar

Tienes que ser un usuario registrado para poder insertar imágenes, archivos y/o videos.

Puedes registrarte o validarte desde aquí.

Codigo
Negrita
Subrayado
Tachado
Cursiva
Insertar enlace
Imagen externa
Emoticon
Tabular
Centrar
Titulo
Linea
Disminuir
Aumentar
Vista preliminar
sonreir
dientes
lengua
guiño
enfadado
confundido
llorar
avergonzado
sorprendido
triste
sol
estrella
jarra
camara
taza de cafe
email
beso
bombilla
amor
mal
bien
Es necesario revisar y aceptar las políticas de privacidad

http://lwp-l.com/s7575