我想更改下面的Python函數,以涵蓋我的business_code需要填充的所有情況。 Python函數處理這個異常,填充到左邊,直到達到給定的寬度,但我從來沒有使用過它。填充函數(Python)string.zfill
#function for formating business codes
def formatBusinessCodes(code):
""" Function that formats business codes. Pass in a business code which will convert to a string with 6 digits """
busCode=str(code)
if len(busCode)==1:
busCode='00000'+busCode
elif len(busCode)==2:
busCode='0000'+busCode
else:
if len(busCode)==3:
busCode='000'+busCode
return busCode
#pad extra zeros
df2['business_code']=df2['business_code'].apply(lambda x: formatBusinessCodes(x))
businessframe['business_code']=businessframe['business_code'].apply(lambda x: formatBusinessCodes(x))
financialframe['business_code']=financialframe['business_code'].apply(lambda x: formatBusinessCodes(x))
上面的代碼處理長度爲6的business_code但我發現的business_codes在長度<變化和> 6。我被狀態驗證數據狀態。每個州的商業代碼長度都不相同(IL - 6 len,OH - 8 len)。所有代碼必須均勻填充。所以IL爲10的代碼應該產生000010等,我需要處理所有異常。使用命令行解析參數(argparse)和string.zfill。
用'究竟string.zfill'什麼問題了嗎? – Cairnarvon 2013-02-25 23:17:50
我的問題是我得到一個TypeError:zfill()只需要1個參數(0給定)。我傳入一個解析參數,詢問用戶業務代碼的長度(parser.add_argument(' - b',help ='指定業務代碼的長度',businessformat = args.d)。我不確定如何使用string.zfill引入參數(def formatBusinessCodes(code):, str.zfill(code)) – Tone 2013-02-26 15:10:53