用python实现日立DCS的atdoc文件整合

项目目的

  • 日立DCS的atdoc文件夹中,有各个控制器的IO清册,但清册分散在各个文件夹中,并无总表

  • 此项目的目的在于将各个文件夹的csv文件整合在一个总表中

项目说明

  • 编程软件 Python 2.7.6
  • 环境 Win 10
  • UI实现 wxPython
  • 软件打包 py2exe

项目目录

image.png

代码实现

功能实现

CSV_Process.py

# -*- coding: UTF-8 -*-
import os
import csv
import sys 
reload(sys) # Python2.5 初始化后会删除 sys.setdefaultencoding 这个方法,我们需要重新载入 
sys.setdefaultencoding('utf-8')

"""
lienDir = "C:\Python27/lelab/atdoc/LH"
resultDir = "C:\Python27/lelab"
"""
def combinecsv(exedir):
    resultDir = exedir[:-6]
    lienDir = resultDir + "/atdoc/LH"
    sheetDI = []
    sheetDO = []
    sheetAI = []
    sheetAO = []
    sheetRTD = []
    sheetTHC = []
    sheetALL = []

    HeadLineAI = ["数据类型".encode('GB18030'), "数据类型".encode('GB18030'), "PI层逻辑页号".encode('GB18030'), "控制器".encode('GB18030'), "", "", "单元号".encode('GB18030'), "槽号".encode('GB18030'), "卡件型号".encode('GB18030'), "", "", "通道序号".encode('GB18030'), "通道号".encode('GB18030'), "信号名称".encode('GB18030'), "物理量程下限".encode('GB18030'), "物理量程上限".encode('GB18030'), "物理量程单位".encode('GB18030'), "span", "工程量程下限".encode('GB18030'), "工程量程上限".encode('GB18030'), "工程量程单位".encode('GB18030'), "执行量程下限".encode('GB18030'), "执行量程上限".encode('GB18030'), "执行量程单位".encode('GB18030'), "诊断量程下限".encode('GB18030'), "诊断量程上限".encode('GB18030'), "IL层逻辑页号".encode('GB18030'), "", "", "KKS".encode('GB18030'), "端子坐标".encode('GB18030'), "内部地址1".encode('GB18030'), "内部地址2".encode('GB18030'), "内部地址3".encode('GB18030')]
    sheetAI.append(HeadLineAI)

    HeadLineALL = ["数据类型".encode('GB18030'), "数据类型".encode('GB18030'), "PI层逻辑页号".encode('GB18030'), "控制器".encode('GB18030'), "", "", "单元号".encode('GB18030'), "槽号".encode('GB18030'), "卡件型号".encode('GB18030'), "", "", "通道序号".encode('GB18030'), "通道号".encode('GB18030'), "信号名称".encode('GB18030'), "IL层逻辑页号".encode('GB18030'), "", "", "KKS".encode('GB18030'), "端子坐标".encode('GB18030'), "内部地址1".encode('GB18030'), "内部地址2".encode('GB18030'), "内部地址3".encode('GB18030')]
    sheetALL.append(HeadLineALL)

    Fatherdir = os.listdir(lienDir)
    for fatherlist in Fatherdir:
        if fatherlist != ".DS_Store":
                liendir = lienDir + "/" + fatherlist + "/pio_ref/pio_csv"
                try:
                    sonDir = os.listdir(liendir)
                    for sonList in sonDir:
                        if sonList != ".DS_Store":
                            csvSample = open(liendir + "/" + sonList, 'rU')
                            csvReader = csv.reader(csvSample)
                            for row in csvReader:
                                if row[0] == "DI32":
                                        row[17] = row[17].replace(' ', '')
                                        sheetDI.append(row)
                                        sheetALL.append(row)
                                elif row[0] == "DO32":
                                        row[17] = row[17].replace(' ', '')
                                        sheetDO.append(row)
                                        sheetALL.append(row)
                                elif row[0] == "AO8 ":
                                        sheetAO.append(row)
                                        row = row[0:14] + row[24:]
                                        row[17] = row[17].replace(' ', '')
                                        sheetALL.append(row)
                                elif row[0] == "AI16":
                                        row[29] = row[29].replace(' ', '')
                                        sheetAI.append(row)
                                        row = row[0:14] + row[26:]
                                        row[17] = row[17].replace(' ', '')
                                        sheetALL.append(row)
                                elif row[0] == "RTD16":
                                        sheetRTD.append(row)
                                        row = row[0:14] + row[24:]
                                        row[17] = row[17].replace(' ', '')
                                        sheetALL.append(row)
                                elif row[0] == "THC ":
                                        sheetTHC.append(row)
                                        row = row[0:14] + row[24:]
                                        row[17] = row[17].replace(' ', '')
                                        sheetALL.append(row)
                            csvSample.close()
                             
                except OSError:
                    print fatherlist + " NO DATA"

    def _savesheet(sourcesheet, desitination):
        writeObj = open(resultDir + '/' + desitination, 'wb')
        writer = csv.writer(writeObj)
        for row in sourcesheet:
            writer.writerow(row)
        writeObj.close()

    _savesheet(sheetDI, "DI.csv")
    _savesheet(sheetDO, "DO.csv")
    _savesheet(sheetAI, "AI.csv")
    _savesheet(sheetAO, "AO.csv")
    _savesheet(sheetRTD, "RTD.csv")
    _savesheet(sheetTHC, "THC.csv")
    _savesheet(sheetALL, "ALL.csv")

    print u"完成"

UI框架

LeGUI_setup.py

# -*- coding: UTF-8 -*-
import os
import csv
import sys 
reload(sys) # Python2.5 初始化后会删除 sys.setdefaultencoding 这个方法,我们需要重新载入 
sys.setdefaultencoding('utf-8')

import wx
from CSV_Process import *

"""
def load(event):
    
    file = open(filename.GetValue())
    
    contents.SetValue(file.read())
    

    file.close()
"""

def load(event):
    dialog = wx.DirDialog(None, 'choose a directory: ', style = wx.DD_DEFAULT_STYLE | wx.DD_NEW_DIR_BUTTON)
    if dialog.ShowModal() == wx.ID_OK:
        path = dialog.GetPath()
        filename.SetValue(path)
        if path[-5:] == "atdoc":
            contents.SetValue("You can execute now")
        else:
            contents.SetValue("Please choose the right path of atdoc")
    dialog.Destroy()


"""
def save(event):
    
    file = open(filename.GetValue(), 'w')
    
    file.write(contents.GetValue())
    
    file.close()
"""

def save(event):
    exedir = filename.GetValue()
    try:
        combinecsv(exedir)
        messageshow("Complete!You can find the csv files in " + exedir[:-6])
    except:
        messageshow("Something is Wrong")


def messageshow(msg):
    dlg = wx.MessageDialog(None, msg, 'A Message Box', wx.OK|wx.ICON_INFORMATION)
    retCode = dlg.ShowModal()
    dlg.Destroy()


app = wx.App(True)

win = wx.Frame(None, title="LeGUI", size=(410,335))



bkg = wx.Panel(win)

loadButton = wx.Button(bkg, label='OPEN')

loadButton.Bind(wx.EVT_BUTTON, load)


saveButton = wx.Button(bkg, label='EXECUTE')

saveButton.Bind(wx.EVT_BUTTON, save)


filename = wx.TextCtrl(bkg)

contents = wx.TextCtrl(bkg, style=wx.TE_MULTILINE | wx.HSCROLL)


hbox = wx.BoxSizer()

hbox.Add(filename, proportion=1, flag=wx.EXPAND)

hbox.Add(loadButton, proportion=0, flag=wx.LEFT, border=5)

hbox.Add(saveButton, proportion=0, flag=wx.LEFT, border=5)


vbox = wx.BoxSizer(wx.VERTICAL)

vbox.Add(hbox, proportion=0, flag=wx.EXPAND | wx.ALL, border=5)

vbox.Add(contents, proportion=1, flag=wx.EXPAND | wx.LEFT | wx.BOTTOM | wx.RIGHT, border=5)


bkg.SetSizer(vbox)

win.Show()


app.MainLoop()

软件打包

LeGUI_setup.py

# -*- coding: utf-8 -*-

from distutils.core import setup
import py2exe

includes = ["encodings", "encodings.*"]
zipfile = r'lib/sharezip'
options = {"py2exe":
            {
                "compressed": 1,
                "optimize": 2,
                "includes": includes
            }
        }

setup(
    version = "1.0",
    description = "H5000M atdoc Combine Tools",
    name = "HAC Tool",
    options = options,
    zipfile = zipfile,
    console = [{"script": "LeGUI.py", "iconresources": [(1, "Hac.icon")] }]
    )
  • Console中进入在LeGUI_setup.py所在的目录中,并执行如下命令生成exe文件
python LeCUI_setup.py install
python LeCUI_setup.py py2exe
  • 在项目目录下生成build、dist文件夹
image.png
  • dist文件夹下有exe执行文件和必须的系统文件,将dist文件夹拷贝到其他WIN10电脑上,即可使用
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,123评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,031评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,723评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,357评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,412评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,760评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,904评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,672评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,118评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,456评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,599评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,264评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,857评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,731评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,956评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,286评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,465评论 2 348

推荐阅读更多精彩内容