利用Python将阿拉伯數字轉化為中文大寫,其實最麻煩的地方就是中間空多個0的問題,這種情況下,采用拆分法則,将一個大數字,先拆分成整數部分和小數部分,再對整數部分按照仟、萬、億、兆分位拆分為四個字元串組成的List,每個字元串最多4個字元,然後對每個分位的字元串用大寫函數轉換成大寫,最後合并,這樣等于縮減了問題,處理就相對簡單了。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
<code>#!/usr/bin/env python</code>
<code># -*- coding: utf-8 -*-</code>
<code>'''</code>
<code>#算法說明:要求字元串輸入,現将字元串差費為整數部分和小數部分生成list[整數部分,小數部分]</code>
<code>#将整數部分拆分為:[億,萬,仟]三組字元串組成的List:['0000','0000','0000'](根據實際輸入生成階梯List)</code>
<code>#例如:600190000010.70整數部分拆分為:['600','1900','0010']</code>
<code>#然後對list中每個字元串分組進行大寫化再合并</code>
<code>#最後處理小數部分的大寫化</code>
<code>class</code> <code>cnumber:</code>
<code> </code><code>cdict</code><code>=</code><code>{}</code>
<code> </code><code>gdict</code><code>=</code><code>{}</code>
<code> </code><code>xdict</code><code>=</code><code>{}</code>
<code> </code><code>def</code> <code>__init__(</code><code>self</code><code>):</code>
<code> </code><code>self</code><code>.cdict</code><code>=</code><code>{</code><code>1</code><code>:u'</code><code>',2:u'</code><code>拾</code><code>',3:u'</code><code>佰</code><code>',4:u'</code><code>仟'}</code>
<code> </code><code>self</code><code>.xdict</code><code>=</code><code>{</code><code>1</code><code>:u</code><code>'元'</code><code>,</code><code>2</code><code>:u</code><code>'萬'</code><code>,</code><code>3</code><code>:u</code><code>'億'</code><code>,</code><code>4</code><code>:u</code><code>'兆'</code><code>} </code><code>#數字辨別符</code>
<code> </code><code>self</code><code>.gdict</code><code>=</code><code>{</code><code>0</code><code>:u</code><code>'零'</code><code>,</code><code>1</code><code>:u</code><code>'壹'</code><code>,</code><code>2</code><code>:u</code><code>'貳'</code><code>,</code><code>3</code><code>:u</code><code>'叁'</code><code>,</code><code>4</code><code>:u</code><code>'肆'</code><code>,</code><code>5</code><code>:u</code><code>'伍'</code><code>,</code><code>6</code><code>:u</code><code>'陸'</code><code>,</code><code>7</code><code>:u</code><code>'柒'</code><code>,</code><code>8</code><code>:u</code><code>'捌'</code><code>,</code><code>9</code><code>:u</code><code>'玖'</code><code>} </code>
<code> </code><code>def</code> <code>csplit(</code><code>self</code><code>,cdata): </code><code>#拆分函數,将整數字元串拆分成[億,萬,仟]的list</code>
<code> </code><code>g</code><code>=</code><code>len</code><code>(cdata)</code><code>%</code><code>4</code>
<code> </code><code>csdata</code><code>=</code><code>[]</code>
<code> </code><code>lx</code><code>=</code><code>len</code><code>(cdata)</code><code>-</code><code>1</code>
<code> </code><code>if</code> <code>g></code><code>0</code><code>:</code>
<code> </code><code>csdata.append(cdata[</code><code>0</code><code>:g])</code>
<code> </code><code>k</code><code>=</code><code>g</code>
<code> </code><code>while</code> <code>k<</code><code>=</code><code>lx:</code>
<code> </code><code>csdata.append(cdata[k:k</code><code>+</code><code>4</code><code>])</code>
<code> </code><code>k</code><code>+</code><code>=</code><code>4</code>
<code> </code><code>return</code> <code>csdata</code>
<code> </code>
<code> </code><code>def</code> <code>cschange(</code><code>self</code><code>,cki): </code><code>#對[億,萬,仟]的list中每個字元串分組進行大寫化再合并</code>
<code> </code><code>lenki</code><code>=</code><code>len</code><code>(cki)</code>
<code> </code><code>i</code><code>=</code><code>0</code>
<code> </code><code>lk</code><code>=</code><code>lenki</code>
<code> </code><code>chk</code><code>=</code><code>u''</code>
<code> </code><code>for</code> <code>i </code><code>in</code> <code>range</code><code>(lenki):</code>
<code> </code><code>if</code> <code>int</code><code>(cki[i])</code><code>=</code><code>=</code><code>0</code><code>:</code>
<code> </code><code>if</code> <code>i<lenki</code><code>-</code><code>1</code><code>:</code>
<code> </code><code>if</code> <code>int</code><code>(cki[i</code><code>+</code><code>1</code><code>])!</code><code>=</code><code>0</code><code>:</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>self</code><code>.gdict[</code><code>int</code><code>(cki[i])] </code>
<code> </code><code>else</code><code>:</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>self</code><code>.gdict[</code><code>int</code><code>(cki[i])]</code><code>+</code><code>self</code><code>.cdict[lk]</code>
<code> </code><code>lk</code><code>-</code><code>=</code><code>1</code>
<code> </code><code>return</code> <code>chk</code>
<code> </code>
<code> </code><code>def</code> <code>cwchange(</code><code>self</code><code>,data):</code>
<code> </code><code>cdata</code><code>=</code><code>str</code><code>(data).split(</code><code>'.'</code><code>)</code>
<code> </code><code>cki</code><code>=</code><code>cdata[</code><code>0</code><code>]</code>
<code> </code><code>if</code> <code>len</code><code>(cdata)</code><code>=</code><code>=</code><code>1</code><code>:</code>
<code> </code><code>i</code><code>=</code><code>0</code>
<code> </code><code>chk</code><code>=</code><code>u''</code>
<code> </code><code>cski</code><code>=</code><code>self</code><code>.csplit(cki) </code><code>#分解字元數組[億,萬,仟]三組List:['0000','0000','0000']</code>
<code> </code><code>ikl</code><code>=</code><code>len</code><code>(cski) </code><code>#擷取拆分後的List長度</code>
<code> </code><code>#大寫合并</code>
<code> </code><code>for</code> <code>i </code><code>in</code> <code>range</code><code>(ikl):</code>
<code> </code><code>if</code> <code>self</code><code>.cschange(cski[i])</code><code>=</code><code>=</code><code>'': </code><code>#有可能一個字元串全是0的情況</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>self</code><code>.cschange(cski[i]) </code><code>#此時不需要将數字辨別符引入</code>
<code> </code><code>else</code><code>:</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>self</code><code>.cschange(cski[i])</code><code>+</code><code>self</code><code>.xdict[ikl</code><code>-</code><code>i] </code><code>#合并:前字元串大寫+目前字元串大寫+辨別符</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>u</code><code>'整'</code>
<code> </code><code>else</code><code>:</code>
<code> </code><code>#處理小數部分</code>
<code> </code><code>ckj</code><code>=</code><code>cdata[</code><code>1</code><code>]</code>
<code> </code><code>lenkj</code><code>=</code><code>len</code><code>(ckj)</code>
<code> </code><code>if</code> <code>lenkj</code><code>=</code><code>=</code><code>1</code><code>: </code><code>#若小數隻有1位</code>
<code> </code><code>if</code> <code>int</code><code>(ckj[</code><code>0</code><code>])</code><code>=</code><code>=</code><code>0</code><code>:</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>u</code><code>'整'</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>self</code><code>.gdict[</code><code>int</code><code>(ckj[</code><code>0</code><code>])]</code><code>+</code><code>u</code><code>'角整'</code>
<code> </code><code>else</code><code>: </code><code>#若小數有兩位的四種情況</code>
<code> </code><code>if</code> <code>int</code><code>(ckj[</code><code>0</code><code>])</code><code>=</code><code>=</code><code>0</code> <code>and</code> <code>int</code><code>(ckj[</code><code>1</code><code>])!</code><code>=</code><code>0</code><code>:</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>u</code><code>'零'</code><code>+</code><code>self</code><code>.gdict[</code><code>int</code><code>(ckj[</code><code>1</code><code>])]</code><code>+</code><code>u</code><code>'分'</code>
<code> </code><code>elif</code> <code>int</code><code>(ckj[</code><code>0</code><code>])</code><code>=</code><code>=</code><code>0</code> <code>and</code> <code>int</code><code>(ckj[</code><code>1</code><code>])</code><code>=</code><code>=</code><code>0</code><code>:</code>
<code> </code><code>elif</code> <code>int</code><code>(ckj[</code><code>0</code><code>])!</code><code>=</code><code>0</code> <code>and</code> <code>int</code><code>(ckj[</code><code>1</code><code>])!</code><code>=</code><code>0</code><code>:</code>
<code> </code><code>chk</code><code>=</code><code>chk</code><code>+</code><code>self</code><code>.gdict[</code><code>int</code><code>(ckj[</code><code>0</code><code>])]</code><code>+</code><code>u</code><code>'角'</code><code>+</code><code>self</code><code>.gdict[</code><code>int</code><code>(ckj[</code><code>1</code><code>])]</code><code>+</code><code>u</code><code>'分'</code>
<code>if</code> <code>__name__</code><code>=</code><code>=</code><code>'__main__'</code><code>:</code>
<code> </code><code>pt</code><code>=</code><code>cnumber()</code>
<code> </code><code>print</code> <code>pt.cwchange(</code><code>'123410505632.09'</code><code>).encode(</code><code>'utf-8'</code><code>)</code>
本文參照網上的一些寫法做了一些改動,使用起來更加嚴謹。
本文轉自 lover00751CTO部落格,原文連結:http://blog.51cto.com/wangwei007/1223368,如需轉載請自行聯系原作者