У Python ви можете використовувати dir
функцію на будь-якому об'єкті, щоб отримати список імен функцій його екземпляра:
>>> dir('abc')
['__add__', '__class__', '__contains__', '__delattr__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__getnewargs__', '__getslice__', '__gt__', '__hash__', '__init__', '__le__', '__len__', '__lt__', '__mod__', '__mul__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__rmod__', '__rmul__', '__setattr__','__sizeof__', '__str__', '__subclasshook__', '_formatter_field_name_split', '_formatter_parser', 'capitalize', 'center', 'count', 'decode', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'index', 'isalnum', 'isalpha', 'isdigit', 'islower', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']
Мені цікаво, чи може це бути корисною програмою для гольфу в програмі, ніж виклик декількох довго названих функцій. У такому випадку я можу створити функцію вибору функції F
:
F=lambda o,i:eval('o.'+dir(o)[i])
Тепер припустимо, що у мене є рядок, s
і я хочу зберегти результат з великої літери у першій букві у змінній c
. Тоді замість цього c=s.capitalize(),
я міг би зазначити, що capitalize
знаходиться у позиції 33 у наведеному вище списку, і зробити наступне:
s='abc'
c=G(s,33)()
який призначає 'Abc'
на c
.
Моє запитання - чи це, ймовірно, спрацює більшу частину часу. Зокрема,
- Чи можна завжди розраховувати, що список буде лексикографічно відсортований за значеннями ASCII?
- Чи багато змін у списку доступних між незначними версіями?
- Чи існують відмінності між реалізаціями?
Також хтось раніше це використовував на PPCG?
dir(__builtins__)
. А ось альтернативна функція: F=lambda o,i:getattr(o,dir(o)[i])
.
()
до кінця F
так: F=lambda o,i:eval('o.'+dir(o)[i])()
Після цього c=F('abc',33)
ви призначите "Abc" c
.