Python: передать индекс списка вызовов функции в качестве собственного аргумента

У меня есть довольно большой (3,9 кБ) скрипт, который предназначен для выравнивания текста на основе некоторых параметров, центрирования и т. Д. Вот блоки, которые я хочу улучшить: (Извиняюсь за некоторый код-гольф, но дело не в этом. что делают функции, кроме их структуры: они работают нормально, как в теории, но мне не терпится сделать их короче)

    #manage + control the margin in spaces between the body text and right vertical rule
def calcMgn(lnNum): return toEven(bwinner-(len(LnOpn[lnNum])+len(LnCtn[lnNum])),-1)//2
def calcRMgn(lnNum): return (0-(1-(toEven(((bwinner-(len(LnOpn[lnNum])+len(LnCtn[lnNum])))//2),-1))))
def calcLenOf(lnNum): return len(LnMgn[lnNum])+len(LnOpn[lnNum])+len(LnCtn[lnNum])+calcRMgn(lnNum)
def calcRDiff(lnNum): return LnMgnR[lnNum] - (lenOf[lnNum] - bwinner)
def calcRMgnSpa(lnNum): return ((LnMgnRAdjust[lnNum])-adjust)
    #there absolutely must be a better way to call a function based on its position in a list than the following:
LnMgn=[calcMgn(0)*spa,calcMgn(1)*spa,calcMgn(2)*spa,calcMgn(3)*spa]
LnMgnR=[calcRMgn(0),calcRMgn(1),calcRMgn(2),calcRMgn(3)]
lenOf=[calcLenOf(0),calcLenOf(1),calcLenOf(2),calcLenOf(3)]
LnMgnRAdjust=[calcRDiff(0),calcRDiff(1),calcRDiff(2),calcRDiff(3)]
LnMgnR_spa=[calcRMgnSpa(0)*spa,calcRMgnSpa(1)*spa,calcRMgnSpa(2)*spa,calcRMgnSpa(3)*spa,]
    #take the lengths for a test drive to see if they break any rules
testLen=[LnMgn[0] + LnOpn[0] + spa + LnCtn[0] + LnMgnR_spa[0],\
LnMgn[1] + LnOpn[1] + spa + LnCtn[1] + LnMgnR_spa[1],\
LnMgn[2] + LnOpn[2] + spa + LnCtn[2] + LnMgnR_spa[2],\
LnMgn[3] + LnOpn[3] + spa + LnCtn[3] + LnMgnR_spa[3]] #instead of this, I want something like a for statement or ???
for i in range(0,3):
    if len(testLen[i]) > bwinner:
        LnMgnR_spa[i] = int((toEven(LnMgnRAdjust[i])-adjust)-(len(testLen[i])-bwinner))*str(spa)
    #concatenate strings
addLine=[idt + vl + LnMgn[0] + LnOpn[0] + spa + LnCtn[0] + LnMgnR_spa[0] + vr + nl,\
idt + vl + LnMgn[1] + LnOpn[1] + spa + LnCtn[1] + LnMgnR_spa[1] + vr + nl,\
idt + vl + LnMgn[2] + LnOpn[2] + spa + LnCtn[2] + LnMgnR_spa[2] + vr + nl,\
idt + vl + LnMgn[3] + LnOpn[3] + spa + LnCtn[3] + LnMgnR_spa[3] + vr + nl]



Я знаю политику SO: "мы не будем писать ваш код для вас", и я определенно не собираюсь просить о таких привилегиях, просто руководство: есть ли способ (и я погуглил, и погуглил), чтобы сделать LnMgn и его Подобные массивы более эффективны и менее огромны по своему содержанию, динамически итеративно вызывая и самоопределяясь на основе индекса их массива?

2 ответа

Решение

Вы также можете создать список функций:

func_list = [f1, f2, f3, f4]

и назовите их, например, как:

[func_list[i](i) for i in range(4)]

Этот пример вернет:

[f1(0), f2(1), f3(2), f4(3)]

Просто используйте понимание списка. Один пример:

LnMgn = [calcMgn(index)*spa for index in range(4)]

Вы можете сделать то же самое для всех остальных.

Другие вопросы по тегам