天天看點

Python将阿拉伯數字轉化為中文大寫

利用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&gt;</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&lt;</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&lt;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,如需轉載請自行聯系原作者