この単純な関数を書きました:
def padded_hex(i, l):
given_int = i
given_len = l
hex_result = hex(given_int)[2:] # remove '0x' from beginning of str
num_hex_chars = len(hex_result)
extra_zeros = '0' * (given_len - num_hex_chars) # may not get used..
return ('0x' + hex_result if num_hex_chars == given_len else
'?' * given_len if num_hex_chars > given_len else
'0x' + extra_zeros + hex_result if num_hex_chars < given_len else
None)
例:
padded_hex(42,4) # result '0x002a'
hex(15) # result '0xf'
padded_hex(15,1) # result '0xf'
これは私にとって十分に明確であり、私のユースケース (単純なプリンター用の単純なテストツール) に適合していますが、改善の余地がたくさんあり、これは非常に簡潔なものに押しつぶされる可能性があると思わずにはいられません。
この問題には他にどのようなアプローチがありますか?