首頁 >後端開發 >Python教學 >Python怎麼實現自動錄入ERP系統數據

Python怎麼實現自動錄入ERP系統數據

PHPz
PHPz轉載
2023-05-10 12:52:062130瀏覽

    專案整體狀況

    軟體:Pycharm

    環境: Python 3.7. 9(考慮到客戶可能會有不同作業系統,為了相容性考慮)

    技術庫: requests、pandas、Pyqt5等(詳見依賴檔案)

    需求分析

    透過對客戶需求文件分析與溝通,大致有以下幾個需求:

    • 根據「單號歸屬」批量向3個介面提交數據

    • 需要一個GUI操作介面

    • 支援不同的業務員登入

    總的來說就是一個POST資料提交和GUI開發。

    專案實作

    1.Post提交

    這一塊主要用到的就是爬蟲技術,萬年不變的步驟,都是先分析網頁。

    1.1登入

    Python怎麼實現自動錄入ERP系統數據

    透過抓包發現,密碼是明文,難度就降低了一半,然後用正確的密碼再分析登入成功後的返回。

        def login(self, username: str, password: str):
            """
            登录
            """
            url = "http://cloud.tiamaes.com:11349/erp/portal.bootstrap/SSOLoginAction/login.do"
            data = {
                "_tp_data": '{"parameters":{"userName":' + username + ',"pwd":' + password + '},"rowsets":{},"headers":{},"requestComponent":"0"}'
            }
            data = parse.urlencode(data).replace("+", "")
            resp = requests.post(url, headers=self.headers, data=data, verify=False)
            self.IDENTIFIER = resp.json()["headers"]["IDENTIFIER"]
            return self.IDENTIFIER

    Python怎麼實現自動錄入ERP系統數據

    發現登入成功後會回傳一個「IDENTIFIER」參數,值是加密字串,這樣就很明顯,光看字面意思都知道這個肯定有用,所以先記錄下來。

    1.2介面分析

    由於我用的是測試帳號,這個帳號提交的資料都要刪掉,為了不給別人注入太多的無效數據,這裡就不再實際錄入,以業務代碼來說明。

    • 獲取車輛資訊

    透過分析發現,雖然客戶給了一部分車輛的信息,但是還有多缺失的信息,需要自己補充。透過抓包發現,在輸入車輛編號以後,會發起一個Ajax請求,表單裡其他資訊就是Ajax請求回傳的資料。

    Python怎麼實現自動錄入ERP系統數據

     def get_car_details(self, car_no: str, IDENTIFIER: str):
            """
            获取车辆信息
            """
            # print(self.IDENTIFIER)
            url = "http://cloud.tiamaes.com:11349/money/basis.inter/JwBusAction/getCacheJwBusByNo.do"
            data = {
                '_tp_data': '{"parameters": {"busNo": ' + str(car_no) + ', "dsName": "83"}, "rowsets": {}, "headers": {"IDENTIFIER": ' + IDENTIFIER + '}, "requestComponent": "0"}'
            }
            data = parse.urlencode(data).replace("+", "")
            resp = requests.post(url, headers=self.headers, data=data, verify=False)
            rows = resp.json()["rowsets"]["com.tp.basis.entity.entity.bus.BaJwBus"]["rows"][0]
            return rows
    • 取得人員資訊

    表單的人員資訊我透過抓包沒有發現,後來再一個頁面中找到了相關的數據。

    Python怎麼實現自動錄入ERP系統數據

    這裡稍微麻煩一點,需要用正規把資料配對出來。

        def get_personal_info(self, IDENTIFIER: str):
            """
            获取个人信息
            """
            url = "http://cloud.tiamaes.com:11349/money/money.action/CharteredAction/showDetail.do"
            data = {
                '_tp_data': '{"parameters":{"dsName":"83","method":"add","recId":"-1"},"rowsets":{},"headers":{"IDENTIFIER":' + IDENTIFIER + '},"requestComponent":"1"}'
            }
            data = parse.urlencode(data).replace("+", "")
            resp = requests.post(url, headers=self.headers, data=data, verify=False)
            json_data = eval(re.findall(r&#39;<code>.*?"rows":\[(.*?)\]&#39;, resp.text)[0])
            return json_data
    • 發起請求,提交資料

    #拿到了登入返回的識別碼、車輛資訊、人員信息,剩下的就是和客戶給的數據結合起來,發起請求。要注意的是,請求參數要轉為url編碼,請求參數也是這個爬蟲裡面最麻煩的部分,這裡要向大家展示一個請求需要發送的參數。

    Python怎麼實現自動錄入ERP系統數據

    參數多,格式要求也比較嚴格,整個開發過程,這裡偵錯花費的時間也最長。調試完正常應該是把程式碼簡化一下,該合併的合併,我調試好了以後懶得再去改了,所以這一塊寫的比較冗餘。

        def submit_data(self, i: dict, IDENTIFIER: str):
            """
            众意数据提交
            """
            personal_info = self.get_personal_info(IDENTIFIER)  # 获取个人信息
            personal_info_data = str(personal_info).replace("&#39;", &#39;"&#39;)  # 将personal_info转换为字符串
            url = "http://cloud.tiamaes.com:11349/money/money.action/CharteredAction/saveForm.do"
            print(f&#39;开始处理--{i["单号归属"]}--数据&#39;)
            memo = f&#39;工单号{i["工单号"]}、餐费{i["餐费"]}、住宿{i["住宿"]}、过路过桥费{i["过路过桥费"]}、油费{i["油费"]}、备注{i["备注"]}&#39;  # 拼接备注信息
            car_infos = self.get_car_details(str(i["车号"]), IDENTIFIER)  # 获取车辆信息
            pay_type = {
                "现金": "3",
                "转账": "2",
                "欠款": "1"
            }
            single_and_double = {
                "单程": "1",
                "双程": "2"
            }
            colType = pay_type[i["结账方式"]]  # 获取结账方式编码
            oddEven = single_and_double[i["单双程"]]  # 获取单双程编码
            now_date = datetime.datetime.now().date().strftime("%Y-%m-%d")  # 获取当前日期
            .......(此处省略)
            data["_tp_data"] = data["_tp_data"].replace(&#39;"dsName":"83"&#39;, &#39;"dsName":"82"&#39;)
            data = parse.urlencode(data).replace("+", "")  # 将字典转换成url编码
            resp = requests.post(url, headers=self.headers, data=data, verify=False).json()
            order_id = resp["rowsets"]["com.tp.money.entity.basic.Chartered"]["rows"][0]["recNo"]  # 获取订单编号
            i["包车单号"] = order_id
            return data

    2.GUI開發

    gui開發相對來說比較簡單,如果不想美化,Pyqt原生的插件就可以了,我這裡是藉用了上一個專案的經驗,用僅有的知識做了一個無邊框介面和適當的美化。

    • 登入

    Python怎麼實現自動錄入ERP系統數據

    #
    from PyQt5.QtCore import Qt
    from PyQt5.QtGui import QColor
    from PyQt5.QtWidgets import (QFrame, QMessageBox, QGraphicsDropShadowEffect)
    from Ui import login_ui
    from Ui.submit_ui_main import MySubmitForm
    from submit import TransitSubmit
     
     
    class MyLogin(login_ui.Ui_LoginForm, QFrame):
        def __init__(self, submit: TransitSubmit):
            super().__init__()
            # self.IDENTIFIER = None
            # self.my_main_window = None
            self.setupUi(self)
            self.submit = submit
            # 设置无边框模式
            self.setWindowFlag(Qt.FramelessWindowHint)  # 将界面设置为无框
            self.setAttribute(Qt.WA_TranslucentBackground)  # 将界面属性设置为半透明
            self.shadow = QGraphicsDropShadowEffect()  # 设定一个阴影,半径为10,颜色为#444444,定位为0,0
            self.shadow.setBlurRadius(10)
            self.shadow.setColor(QColor("#444444"))
            self.shadow.setOffset(0, 0)
            self.frame.setGraphicsEffect(self.shadow)  # 为frame设定阴影效果
            # ------------------------------------------------
            self.show()
            self.pushButton_3.clicked.connect(self.close)  # 关闭按钮
            self.pushButton_login.clicked.connect(self.do_login)  # 登录按钮
     
        # 以下是控制窗口移动的代码
        def mousePressEvent(self, event):  # 鼠标左键按下时获取鼠标坐标,按下右键取消
            if event.button() == Qt.LeftButton:
                self.m_flag = True
                self.m_Position = event.globalPos() - self.pos()
                event.accept()
            elif event.button() == Qt.RightButton:
                self.m_flag = False
     
        def mouseMoveEvent(self, QMouseEvent):  # 鼠标在按下左键的情况下移动时,根据坐标移动界面
            if Qt.LeftButton and self.m_flag:
                self.move(QMouseEvent.globalPos() - self.m_Position)
                QMouseEvent.accept()
     
        def mouseReleaseEvent(self, QMouseEvent):  # 鼠标按键释放时,取消移动
            self.m_flag = False
     
        # 登录事件
        def do_login(self):
            username = self.lineEdit_username.text()
            password = self.lineEdit_password.text()
            if not username or not password:
                QMessageBox.warning(self, &#39;警告&#39;, &#39;用户名或密码不能为空&#39;, QMessageBox.Yes)
                return
            else:
                IDENTIFIER = self.submit.login(username, password)
                if not IDENTIFIER:
                    QMessageBox.warning(self, &#39;警告&#39;, &#39;用户名或密码错误&#39;, QMessageBox.Yes)
                    return
                self.hide()  # 隐藏登录界面
                my_submit_form = MySubmitForm(self.submit, IDENTIFIER)
                my_submit_form.exec_()  # 显示主界面
    • 業務作業

    Python怎麼實現自動錄入ERP系統數據

    class MySubmitForm(submitform_ui.Ui_Dialog_Submit, QDialog):
        def __init__(self, submit: TransitSubmit, IDENTIFIER: str):
            super().__init__()
            ......
            self.setupUi(self)
            ......
            self.progressBar.hide()  # 关闭进度条显示
            self.setWindowFlags(Qt.FramelessWindowHint)  # 无边框
            self.setAttribute(Qt.WA_TranslucentBackground)  # 设置窗口透明
            self.pushButton_mini.clicked.connect(self.showMinimized)  # 实现最小化
            self.pushButton_close.clicked.connect(self.close)  # 实现关闭功能
            ......
            self.show()
     
        # 实现鼠标拖拽功能
        def mousePressEvent(self, event):
            self.pressX = event.x()  # 记录鼠标按下的时候的坐标
            self.pressY = event.y()
     
        def mouseMoveEvent(self, event):
            x = event.x()
            y = event.y()  # 获取移动后的坐标
            moveX = x - self.pressX
            moveY = y - self.pressY  # 计算移动了多少
            positionX = self.frameGeometry().x() + moveX
            positionY = self.frameGeometry().y() + moveY  # 计算移动后主窗口在桌面的位置
            self.move(positionX, positionY)  # 移动主窗口
        ......

    這裡多說一嘴,最開始這裡我用的和登入一樣,使用的是QFrame,但是它沒有exec()方法,登入成功後不能彈出,也可能是我知識有限,做不出來。透過分析原始碼,發現QDialog有這個方法,可以實現彈出,後來又改了用QDialog做了一個無邊框介面。

    剩下的打包就不多說了,網上的教程很多,我這裡用的是—D打包,用了upx壓縮,改了圖標,打包完整個項目有50多M。

    以上是Python怎麼實現自動錄入ERP系統數據的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    陳述:
    本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除