VAC (Doxorrubicina) alternando con IE - sarcomas

VAC - IE


# -*- coding: utf-8 -*-
def unidades(x):
if x == 0:
unidad = "cero"
if x == 1:
unidad = "un"
if x == 2:
unidad = "dos"
if x == 3:
unidad = "tres"
if x == 4:
unidad = "cuatro"
if x == 5:
unidad = "cinco"
if x == 6:
unidad = "seis"
if x == 7:
unidad = "siete"
if x == 8:
unidad = "ocho"
if x == 9:
unidad = "nueve"
return unidad

def teens(x):
if x == 0:
teenname = "diez"
if x == 1:
teenname = "once"
if x == 2:
teenname = "doce"
if x == 3:
teenname = "trece"
if x == 4:
teenname = "catorce"
if x == 5:
teenname = "quince"
return teenname


def tens(x):
if x == 1:
tensname = "diez"
if x == 2:
tensname = "veinte"
if x == 3:
tensname = "treinta"
if x == 4:
tensname = "cuarenta"
if x == 5:
tensname = "cincuenta"
if x == 6:
tensname = "sesenta"
if x == 7:
tensname = "setenta"
if x == 8:
tensname = "ochenta"
if x == 9:
tensname = "noventa"
return tensname

def tercia(num):
numero=str(num)
if len(numero) == 1:
numero='00'+numero
if len(numero) == 2:
numero='0'+numero
a=int(numero[0])
b=int(numero[1])
c=int(numero[2])
# print a, b, c
if a == 0:
if b == 0:
resultado=unidades(c)
return resultado
elif b == 1:
if c >= 0 and c <= 5:
resultado = teens(c)
return resultado
elif c >= 6 and c <= 9:
resultado = tens(b)+' y '+unidades(c)
return resultado
elif b == 2:
if c == 0:
resultado = 'veinte'
return resultado
elif c > 0 and c <= 9:
resultado ='veinti '+unidades(c)
return resultado
elif b >=3 and b <= 9:
if c == 0:
resultado = tens(b)
return resultado
if c >= 1 and c <= 9:
resultado = tens(b)+' y '+unidades(c)
return resultado
if a == 1:
if b == 0:
if c == 0:
resultado = 'cien'
return resultado
elif c > 0 and c <= 9:
resultado ='ciento '+unidades(c)
return resultado
elif b == 1:
if c >= 0 and c <= 5:
resultado = 'ciento '+teens(c)
return resultado
elif c >= 6 and c <= 9:
resultado = 'ciento '+tens(b)+' y '+unidades(c)
return resultado
elif b == 2:
if c == 0:
resultado = 'ciento veinte'
return resultado
elif c > 0 and c <= 9:
resultado ='ciento veinti '+unidades(c)
return resultado
elif b >= 3 and b <= 9:
if c == 0:
resultado = 'ciento '+tens(b)
return resultado
elif c > 0 and c <= 9:
resultado = 'ciento '+tens(b)+ ' y '+unidades(c
)
return resultado

elif a >= 2 and a <= 9:
if a == 5:
prefix='quinientos '
elif a == 7:
prefix='setecientos '
elif a == 9:
prefix='novecientos '
else:
prefix=unidades(a)+' cientos '
if b == 0:
if c == 0:
resultado = prefix
return resultado
elif c > 0 and c <= 9:
resultado = prefix+unidades(c)
return resultado
elif b == 1:
if c >= 0 and c <= 5:
resultado = prefix+teens(c)
return resultado
elif c >= 6 and c <= 9:
resultado = prefix+tens(b)+' y '+unidades(c)
return resultado
elif b == 2:
if c == 0:
resultado = prefix+' veinte'
return resultado
elif c > 0 and c <= 9:
resultado = prefix+' veinti '+unidades(c)
return resultado
elif b >= 3 and b <= 9:
if c == 0:
resultado = prefix+tens(b)
return resultado
elif c > 0 and c <= 9:
resultado = prefix+tens(b)+' y '+unidades(c)
return resultado
def main(num):
result=''
numero=str(num)
if len(numero) == 1:
numero='00000000'+numero
if len(numero) == 2:
numero='0000000'+numero
if len(numero) == 3:
numero='000000'+numero
if len(numero) == 4:
numero='00000'+numero
if len(numero) == 5:
numero='0000'+numero
if len(numero) == 6:
numero='000'+numero
if len(numero) == 7:
numero='00'+numero
if len(numero) == 8:
numero='0'+numero
posicion=1
for i in [0,3,6]:
var=numero[i]+numero[i+1]+numero[i+2]
if int(var) != 0:
res=tercia(var)
if i == 0:
result=res+" millones "
elif i == 3:
result=result+res+" mil "
elif i == 6:
result=result+res
return result

# Superficie corporal (BSA)
def f_BSA(Ta, Pe):
# Calculo de la superficie corporal utilizando
# de estatura en cms, y kg de peso
BSA = (0.007184 * ((Ta)**0.725)) * (Pe ** (0.425))
return BSA

def f_dosis_BSA(Dosis, BSA, Porcentaje):
# Calculo de la dosis por m2 de superficie corporal,
# e intensidad relativa en porcentaje
f_dosis_BSA = Dosis * BSA * (Porcentaje/100)
return f_dosis_BSA

def f_dosis_Kg(Dosis, Peso, Porcentaje):
# Calculo de la dosis por m2 de superficie corporal,
# e intensidad relativa en porcentaje
f_dosis_Kg = Dosis * Peso * (Porcentaje/100)
return f_dosis_Kg

def f_numero_ampollas (Presentacion, DosisTotal, NumeroDeAplicacionesCiclo):
# NTAA = numerototaldeampollasrequerida
NTAA = float (DosisTotal/Presentacion)
if int(NTAA) != NTAA:
NTAA = int(NTAA)+1
NTAA = NTAA * NumeroDeAplicacionesCiclo
return NTAA

def f_protocolo_droga_BSA (Droga1, DiaAdministracion1, ViaAdministracion1, Posologia1, Unidades1, Dosis1, PorcentajeDosis1, NumeroDeAplicacionesCiclo1, Presentacion1, Comentario1):
DosisTotal1 = f_dosis_BSA(Dosis1, SuperficieCorporal , PorcentajeDosis1)
NumeroDeAmpollasCiclo1 = f_numero_ampollas (Presentacion1, DosisTotal1, NumeroDeAplicacionesCiclo1)
StrDroga1 = Droga1 + " " + Posologia1 + " " + str(Presentacion1)+ " " + Unidades1 + " "
StrDroga1 = StrDroga1 + "# " + str((NumeroDeAmpollasCiclo1)) + " (" + main(str((NumeroDeAmpollasCiclo1))) + ") " + Posologia1 + ": " + str(round(float(DosisTotal1),2)) + " " + str(Unidades1) + " " + " "
StrDroga1 = StrDroga1 + ViaAdministracion1
print(StrDroga1)
print(Comentario1)

def f_protocolo_droga_ABSOLUTO (Droga1, DiaAdministracion1, ViaAdministracion1, Posologia1, Unidades1, Dosis1, PorcentajeDosis1, NumeroDeAplicacionesCiclo1, Presentacion1, Comentario1):
DosisTotal1 = Dosis1
NumeroDeAmpollasCiclo1 = f_numero_ampollas (Presentacion1, DosisTotal1, NumeroDeAplicacionesCiclo1)
if int(NumeroDeAmpollasCiclo1) ==0:
NumeroDeAmpollasCiclo1 = 1
StrDroga1 = Droga1 + " " + Posologia1 + " " + str(Presentacion1)+ " " + Unidades1 + " "
StrDroga1 = StrDroga1 + "# " + str(int(NumeroDeAmpollasCiclo1)) + " (" + main(str(int(NumeroDeAmpollasCiclo1))) + ") " + Posologia1 + ": " + str(DosisTotal1) + " " + str(Unidades1) + " " + " "
StrDroga1 = StrDroga1 + ViaAdministracion1
print(StrDroga1)
print(Comentario1)

def f_protocolo_droga_Kg (Droga1, DiaAdministracion1, ViaAdministracion1, Posologia1, Unidades1, Dosis1, PorcentajeDosis1, NumeroDeAplicacionesCiclo1, Presentacion1, Comentario1):
DosisTotal1 = f_dosis_Kg(Dosis1, Peso , PorcentajeDosis1)
NumeroDeAmpollasCiclo1 = f_numero_ampollas (Presentacion1, DosisTotal1, NumeroDeAplicacionesCiclo1)
StrDroga1 = Droga1 + " " + Posologia1 + " " + str(Presentacion1)+ " " + Unidades1 + " "
StrDroga1 = StrDroga1 + "# " + str(int(NumeroDeAmpollasCiclo1)) + " (" + main(str(int(NumeroDeAmpollasCiclo1))) + ") " + Posologia1 + ": " + str(int(DosisTotal1)) + " " + str(Unidades1) + " " + " "
StrDroga1 = StrDroga1 + ViaAdministracion1
print(StrDroga1)
print(Comentario1)
print("VAC: Vincristina: 1.5 mg/m2 (máximo 2) d1; ciclofosfamida 1200 mg/m2 d1; MESNA 1200 mg/m2 d1; Doxorrubicina 37.5 mg/m2, días 2 y 3; pegfilgrastim día 4; alternando cada 3 semanas con IE: Ifosfamida 1800 mg/m2 días 1-5; MESNA 1800 mg/m2/días 1 a 5; Etopósido 100 mg/m2 días 1-5; pegfilgrastim día 6\n\nIngrese los siguientes datos>>")
tTalla = input("Estatura en centimetros?>>")
Talla = float(tTalla)
tPeso = input("Peso en kilogramos?>>")
Peso = float(tPeso)


SuperficieCorporal = f_BSA(Talla, Peso)

print()
print()
print("VAC alternando con IE")
print("VAC alternante ciclos 1,3,5,7,8,9 y al IE alternante ciclos 2,4,6,8,10")
print("Ciclofosfamida 1200 mg/m2, d1")
print("MESNA 1200 mg/m2, d1")
print("Vincristina 1.5 mg/m2 (máximo 2 mg), día 1")
print("Doxorrubicina 37.5 mg/m2, d2, d3")
print("Se alterna cada 21 días con IE así:")
print("Ifosfamida 1800 mg/m2, d1, d2, d3, d4, d5.")
print("MESNA 1800 mg/m2, d1, d2, d3, d4, d5.")
print("Etopósido 100 mg/m2, d1, d2, d3, d4, d5.")
print("Peso: " + tPeso + "kg.")
print("Talla: " + tTalla + "cms.")
print("Superficie corporal (m2): ")
print(round(f_BSA(Talla, Peso),2))
print()
print("VAC - intrahospitalario")
print("Hospitalizar, iniciar hidratación con Solución Salina normal 100 mL/hora, durante la hospitalización - días 1-4")
print("Ondansetron ampollas 8 miligramos #8 (Ocho): administrar 8 miligramos intravenosos, cada 12 horas, dia 1, 2, 3 y 4.")
print("Dexametasona ampollas 4 miligramos #20 (veinte): administrar 20 miligramos intravenosos días, 1, 2, 3 y 4.")
print("Fosaprepitant ampollas 150 miligramos #1 (uno): administrar 150 miligramos intravenosos dia 1.")
f_protocolo_droga_BSA("Ciclofosfamida", "por 1 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 1200, 100, 1, 1000, "Administrar intravenoso, dia 1.")
f_protocolo_droga_BSA("MESNA", "por 1 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 1200, 100, 1, 400, "Administrar intravenoso (junto con ciclofosfamida), dia 1.")
if SuperficieCorporal*1.5 >2:
f_protocolo_droga_ABSOLUTO("Vincristina", "por 1 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 2, 100, 1, 1, "Administrar intravenoso, dia 1.")
if SuperficieCorporal*1.5 <=2:
f_protocolo_droga_BSA("Vincristina", "por 1 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 1.5, 100, 1, 1, "Administrar intravenoso, dia 1.")
f_protocolo_droga_BSA("Doxorrubicina", "por 2 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 37.5, 100, 2, 10, "Administrar intravenoso, dias 2 y 3.")
print("Pegfilgastrim ampollas 6 miligramos #1 (uno): administrar 6 miligramos subcutaneos, dia 4.")
print("Ondansetron tabletas 8 miligramos #60 (sesenta): tomar 8 miligramos via oral, cada 12 horas (para nauseas y vomito).")
print("Olanzapina tabletas 10 miligramos #5 (cinco): tomar 10 miligramos via oral, cada día por 5 dias, a partir del dia de la quimioterapia (para nauseas y vomito).")
print("Espirinolactona tabletas 25 miligramos #60 (sesenta): tomar 25 miligramos via oral, cada 12 horas (para evitar cardiotoxicidad).")
print("NOTA: repetir VAC máximo por 6 ciclos")
print("")
print("Alternar cada 21 días con:")
print("IE - intrahospitalario")
print("Hospitalizar, iniciar hidratación con Solución Salina normal 100 mL/hora, durante la hospitalización - días 1-5")
print("Ondansetron ampollas 8 miligramos #12 (Doce): administrar 8 miligramos intravenosos, cada 12 horas, dia 1, 2, 3, 4, 5 y 6.")
print("Dexametasona ampollas 4 miligramos #25 (veinticinco): administrar 20 miligramos intravenosos días, 1, 2, 3, 4 y 5.")
print("Fosaprepitant ampollas 150 miligramos #1 (uno): administrar 150 miligramos intravenosos dia 1.")
f_protocolo_droga_BSA("Ifosfamida", "por 5 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 1800, 100, 5, 1000, "Administrar intravenoso, dias 1, 2, 3, 4 y 5.")
f_protocolo_droga_BSA("MESNA", "por 5 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 1800, 100, 5, 400, "Administrar intravenoso, concomitante con ifosfamida, dias 1, 2, 3, 4 y 5.")
f_protocolo_droga_BSA("Etopósido", "por 5 dosis / ciclo", "Intravenoso", "ampollas" , "miligramos", 100, 100, 5, 100, "Administrar intravenoso, dias 1, 2, 3, 4 y 5.")
print("Pegfilgastrim ampollas 6 miligramos #1 (uno): administrar 6 miligramos subcutaneos, dia 6.")
print("Ondansetron tabletas 8 miligramos #60 (sesenta): tomar 8 miligramos via oral, cada 12 horas (para nauseas y vomito).")

Comentarios