Re: [問題] GUID 字串格式轉換
※ 引述《LwHow (Do)》之銘言:
: 0x798ffd60, 0xf10e, 0x4ac4, 0x89, 0x39, 0xc8, 0xbe, 0xab, 0xfe, 0x55, 0xb4
: 798ffd60-f10e-4ac4-8939-c8beabfe55b4
: 有一個重點就是,格式必須要符合寬度
: 例如 第一組資料如果是0xffd60,則我們必須把資料補滿為
: 000ffd60-xxxx-xxxx-xxxx-xxxxxxxx
: 其他欄位以此類推
推
07/21 09:19,
07/21 09:19
→
07/21 09:20,
07/21 09:20
我沒看你的程式, 不過按照你的需求, 假設最後面那組也是補 leading zeros
那麼可以這樣寫 (需要 Python 3)
# 把資料用逗號拆開, 每筆去掉前後空白和 0x 開頭
# 前三筆叫 first second third, 剩下的放到 rest_parts (會是個 list)
first, second, third, *rest_parts = [s.strip()[2:] for s in source.split(',')]
# 把 rest_parts join 起來叫做 rest, 然後組合成結果
# 每個 variable 後面的 : 代表資料格式, 後面格式符號的意思是:
# > 代表向右對齊
# 0 代表前面補 0
# 最後一位數字代表至少補到幾位
output = '{first:0>8}-{second:0>4}-{third:0>4}-{rest:0>8}'.format(
first=first, second=second, third=third,
rest=''.join(p.zfill(2) for p in rest_parts),
)
--
→
08/10 00:59,
08/10 00:59
→
08/10 02:16,
08/10 02:16
→
08/10 20:18,
08/10 20:18
→
08/10 20:19,
08/10 20:19
→
08/10 20:21,
08/10 20:21
→
08/11 20:23,
08/11 20:23
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 218.161.19.12
※ 文章網址: https://www.ptt.cc/bbs/Python/M.1500614456.A.B0F.html
→
07/21 13:24, , 1F
07/21 13:24, 1F
※ 編輯: uranusjr (218.161.19.12), 07/21/2017 13:36:15
推
07/21 13:44, , 2F
07/21 13:44, 2F
推
07/21 13:48, , 3F
07/21 13:48, 3F
推
07/21 13:50, , 4F
07/21 13:50, 4F
推
07/21 13:54, , 5F
07/21 13:54, 5F
→
07/21 13:54, , 6F
07/21 13:54, 6F
→
07/21 14:34, , 7F
07/21 14:34, 7F
※ 編輯: uranusjr (140.112.94.57), 07/21/2017 14:35:24
→
07/21 14:36, , 8F
07/21 14:36, 8F
推
07/21 14:43, , 9F
07/21 14:43, 9F
→
07/21 14:44, , 10F
07/21 14:44, 10F
討論串 (同標題文章)