欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python操作Word批量生成合同的實(shí)現(xiàn)示例

 更新時(shí)間:2020年08月28日 09:56:15   作者:雨哥不劃水  
這篇文章主要介紹了Python操作Word批量生成合同的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

背景:大約有3K家商家需要重新確認(rèn)信息并簽訂合同。合同是統(tǒng)一的Word版本。每個供應(yīng)商需要修改合同內(nèi)的金額部分。人工處理方式需要每個復(fù)制粘貼且金額要生成大寫金額?;谥貜?fù)工作可偷懶。用Python解救一下。

#導(dǎo)入對應(yīng)數(shù)據(jù)庫
import numpy as np 
import pandas as pd 
import os 
import docx
from docx.shared import Pt
from docx.oxml.ns import qn
#修改項(xiàng)目文件地址
os.chdir(r'C:\Users\WIN7\Desktop\分期賬單自動化')
os.getcwd()

'''
人民幣數(shù)字轉(zhuǎn)大寫漢字
'''
# coding: utf-8
import warnings
from decimal import Decimal

def cncurrency(value, capital=True, prefix=False, classical=None):
  '''
  參數(shù):
  capital:  True  大寫漢字金額
        False 一般漢字金額
  classical: True  元
        False 圓
  prefix:   True  以'人民幣'開頭
        False, 無開頭
  '''
  if not isinstance(value, (Decimal, str, int)):
    msg = '''
    由于浮點(diǎn)數(shù)精度問題,請考慮使用字符串,或者 decimal.Decimal 類。
    因使用浮點(diǎn)數(shù)造成誤差而帶來的可能風(fēng)險(xiǎn)和損失作者概不負(fù)責(zé)。
    '''
    warnings.warn(msg, UserWarning)
  # 默認(rèn)大寫金額用圓,一般漢字金額用元
  if classical is None:
    classical = True if capital else False
    
  # 漢字金額前綴
  if prefix is True:
    prefix = '人民幣'
  else:
    prefix = ''
    
  # 漢字金額字符定義
  dunit = ('角', '分')
  if capital:
    num = ('零', '壹', '貳', '叁', '肆', '伍', '陸', '柒', '捌', '玖')
    iunit = [None, '拾', '佰', '仟', '萬', '拾', '佰', '仟','億', '拾', '佰', '仟', '萬', '拾', '佰', '仟']
  else:
    num = ('〇', '一', '二', '三', '四', '五', '六', '七', '八', '九')
    iunit = [None, '十', '百', '千', '萬', '十', '百', '千','億', '十', '百', '千', '萬', '十', '百', '千']
  if classical:
    iunit[0] = '元' if classical else '圓'
  # 轉(zhuǎn)換為Decimal,并截?cái)喽嘤嘈?shù)

  if not isinstance(value, Decimal):
    value = Decimal(value).quantize(Decimal('0.01'))

  # 處理負(fù)數(shù)
  if value < 0:
    prefix += '負(fù)'     # 輸出前綴,加負(fù)
    value = - value     # 取正數(shù)部分,無須過多考慮正負(fù)數(shù)舍入
                # assert - value + value == 0
  # 轉(zhuǎn)化為字符串
  s = str(value)
  if len(s) > 19:
    raise ValueError('金額太大了,不知道該怎么表達(dá)。')
  istr, dstr = s.split('.')      # 小數(shù)部分和整數(shù)部分分別處理
  istr = istr[::-1]          # 翻轉(zhuǎn)整數(shù)部分字符串
  so = []   # 用于記錄轉(zhuǎn)換結(jié)果
  
  # 零
  if value == 0:
    return prefix + num[0] + iunit[0]
  haszero = False   # 用于標(biāo)記零的使用
  if dstr == '00':
    haszero = True # 如果無小數(shù)部分,則標(biāo)記加過零,避免出現(xiàn)“圓零整”
    
  # 處理小數(shù)部分
  # 分
  if dstr[1] != '0':
    so.append(dunit[1])
    so.append(num[int(dstr[1])])
  else:
    so.append('整')     # 無分,則加“整”
  # 角
  if dstr[0] != '0':
    so.append(dunit[0])
    so.append(num[int(dstr[0])])
  elif dstr[1] != '0':
    so.append(num[0])    # 無角有分,添加“零”
    haszero = True     # 標(biāo)記加過零了
    
  # 無整數(shù)部分
  if istr == '0':
    if haszero:       # 既然無整數(shù)部分,那么去掉角位置上的零
      so.pop()
    so.append(prefix)    # 加前綴
    so.reverse()      # 翻轉(zhuǎn)
    return ''.join(so)

  # 處理整數(shù)部分
  for i, n in enumerate(istr):
    n = int(n)
    if i % 4 == 0:     # 在圓、萬、億等位上,即使是零,也必須有單位
      if i == 8 and so[-1] == iunit[4]:  # 億和萬之間全部為零的情況
        so.pop()            # 去掉萬
      so.append(iunit[i])
      if n == 0:             # 處理這些位上為零的情況
        if not haszero:         # 如果以前沒有加過零
          so.insert(-1, num[0])    # 則在單位后面加零
          haszero = True       # 標(biāo)記加過零了
      else:                # 處理不為零的情況
        so.append(num[n])
        haszero = False         # 重新開始標(biāo)記加零的情況
    else:                  # 在其他位置上
      if n != 0:             # 不為零的情況
        so.append(iunit[i])
        so.append(num[n])
        haszero = False         # 重新開始標(biāo)記加零的情況
      else:                # 處理為零的情況
        if not haszero:         # 如果以前沒有加過零
          so.append(num[0])
          haszero = True

  # 最終結(jié)果
  so.append(prefix)
  so.reverse()
  return ''.join(so)
#數(shù)據(jù)準(zhǔn)備階段 導(dǎo)入大寫
#讀取預(yù)備好的EXCEL表格
text = pd.read_excel('付款預(yù)備表.xlsx')
#print(text)
text['EC總應(yīng)付額']
list1 = []
for i in text['EC總應(yīng)付額']:
  list1.append(cncurrency(str(i)))
text.append(list1)
text['大寫金額'] = list1
text.shape[0]
print(text.head())
document12 = docx.Document('分期SPM模板(12期).docx')
document24 = docx.Document('分期SPM模板(24期).docx')
supp_num = 0 
for supp_num in range(text.shape[0]):
  paragraph_num = 0
  A = text.iat[supp_num,2]
  B = text.iat[supp_num,5]
  qishu = text.iat[supp_num,3]
  supp_name = text.iat[supp_num,1]
  user_name = text.iat[supp_num,4]
  content = "雙方確認(rèn),截止至 2020 年 3 月 31 日,扣除原合同和原合作約定到貨異常(包括但不僅限于缺貨、少貨、貨損、到貨不符)、違約責(zé)任、賠償責(zé)任、甲方代乙方墊付等所涉相關(guān)費(fèi)用后,甲方尚欠付乙方貨款金額合計(jì)人民幣{}元(大寫:{})。".format(A,B)
  if qishu == "12期":
    p = document12.paragraphs[8].clear()
    run1 = p.add_run(content)
    run1.font.size = Pt(12)
    run1.font.name = '仿宋'
    run1.element.rPr.rFonts.set(qn('w:eastAsia'), '仿宋')
    document12.save("{}.docx".format(supp_name))
  else:
    p = document24.paragraphs[8].clear()
    run1 = p.add_run(content)
    run1.font.size = Pt(12)
    run1.font.name = '仿宋'
    run1.element.rPr.rFonts.set(qn('w:eastAsia'), '仿宋')
    document24.save("{}.docx".format(supp_name))

主要是分成四個板塊。
 一:導(dǎo)入相關(guān)的包,這個就不說了
 二:數(shù)字金額轉(zhuǎn)大寫金額。這個網(wǎng)上一大堆的現(xiàn)成的函數(shù),也就不用自己寫,Copy測試一下,OK的。
 三:預(yù)備自己的數(shù)據(jù)。
 四:本來想替換指定位置的內(nèi)容的,但是發(fā)現(xiàn)操作相對有點(diǎn)困難,那就思維放大,直接替換整個段落。用個format,把需要替換的內(nèi)容直接填入。然后用docx包里面的.clear【清除段落】 加 add_run【添加段落】的方式,配合上.font.size 和.font.name 調(diào)整字體大小與字體。最后save就OJBK了。

到此這篇關(guān)于Python操作Word批量生成合同的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Python批量替換word內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論