zoukankan      html  css  js  c++  java
  • 配置文件的自动化更新(v4.1)

     1 import openpyxl
     2 import configparser
     3 
     4 
     5 conf = configparser.ConfigParser()
     6 
     7 conf.read("E:Projectswork_11_25\Utility機種対応知能化\Network Extension\NETX_ALL_010500_6setupdirlangJPNopnedef.str", encoding='shift_jis')
     8 sections = conf.sections()
     9 
    10 # ['common', 'StrTable0', 'StrTable1', 'StrTable2', 'StrTable3', 'StrTable4', 'StrTable5', 'StrTable6', 'StrTable7', 'StrTable8', 'StrTable9']
    11 
    12 wb = openpyxl.load_workbook("E:Projectswork_11_25\Utility機種対応知能化\Utility機種対応仕様.xlsx")
    13 
    14 ws = wb["NetworkExtension"]
    15 
    16 
    17 
    18 with open("E:Projectswork_11_25\Utility機種対応知能化\Network Extension\NETX_ALL_010500_6setupdirlangJPNopnedef.str", "r", encoding="shift_jis") as f1:
    19     lines = f1.readlines()
    20     index_list = []
    21     for line in lines[4:]:
    22         if '[' in line and ']' in line:
    23             index_list.append(lines.index(line))
    24 
    25     index_list.append(len(lines) + 1)
    26     kv_list = []
    27     options = []
    28     value = []
    29     for i in range(len(index_list) - 1):
    30         items = lines[index_list[i]: index_list[i + 1] - 1]
    31         for kv in items[1:]:
    32             kv = kv.split('=')
    33             options.append(kv[0])
    34             if kv == ['
    ']:
    35                 kv.append('
    ')
    36             value.append(kv[1].strip())
    37     # print(options)
    38     # print(value)
    39 
    40 ws['E4'].value = lines[0]+lines[1]+lines[2]
    41 # print("head完成")
    42 
    43 
    44 n = 5
    45 for a in options:
    46     ws["D" + str(n)].value = a
    47     n += 1
    48 
    49 n = 5
    50 for b in value:
    51     ws["E" + str(n)].value = b
    52     n += 1
    53 
    54 m = 0
    55 x = -1
    56 for s in sections:
    57     ws['C' + str(index_list[m] - x)].value = s
    58     x += 2
    59     m += 1
    60 
    61 wb.save("test.xlsx")
  • 相关阅读:
    [开源] FreeSql.AdminLTE 功能升级
    [开源] .NETCore websocket 即时通讯组件---ImCore
    [开源] FreeSql 配套工具,基于 Razor 模板实现最高兼容的生成器
    Redis 基础数据结构
    Keepalived 原理与实战
    反向代理与负载均衡
    Nginx 安装与配置
    CentOS 7.x编写开机启动服务
    Mac 软件包管理器Homebrew使用指北
    Springboot 关于日期时间格式化处理方式总结
  • 原文地址:https://www.cnblogs.com/wangzhilong/p/11943758.html
Copyright © 2011-2022 走看看