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

    專案整體狀況

    軟體: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中文網其他相關文章!

    陳述
    本文轉載於:亿速云。如有侵權,請聯絡admin@php.cn刪除
    您如何將元素附加到Python數組?您如何將元素附加到Python數組?Apr 30, 2025 am 12:19 AM

    Inpython,YouAppendElementStoAlistusingTheAppend()方法。 1)useappend()forsingleelements:my_list.append(4).2)useextend()orextend()或= formultiplelements:my_list.extend.extend(emote_list)ormy_list = [4,5,6] .3)useInsert()forspefificpositions:my_list.insert(1,5).beaware

    您如何調試與Shebang有關的問題?您如何調試與Shebang有關的問題?Apr 30, 2025 am 12:17 AM

    調試shebang問題的方法包括:1.檢查shebang行確保是腳本首行且無前置空格;2.驗證解釋器路徑是否正確;3.直接調用解釋器運行腳本以隔離shebang問題;4.使用strace或truss跟踪系統調用;5.檢查環境變量對shebang的影響。

    如何從python數組中刪除元素?如何從python數組中刪除元素?Apr 30, 2025 am 12:16 AM

    pythonlistscanbemanipulationusseveralmethodstoremovelements:1)theremove()MethodRemovestHefirStocCurrenceOfAstePecificiedValue.2)thepop()thepop()methodRemovesandReturnturnturnturnsanaNelementAgivenIndex.3)

    可以在Python列表中存儲哪些數據類型?可以在Python列表中存儲哪些數據類型?Apr 30, 2025 am 12:07 AM

    pythonlistscanstoreanydatate型,包括素,弦,浮子,布爾人,其他列表和迪克尼亞式

    在Python列表上可以執行哪些常見操作?在Python列表上可以執行哪些常見操作?Apr 30, 2025 am 12:01 AM

    pythristssupportnumeroferations:1)addingElementSwithAppend(),Extend(),andInsert()。 2)emovingItemSusingRemove(),pop(),andclear(),and clear()。 3)訪問andModifyingandmodifyingwithIndexingandSlicing.4)

    如何使用numpy創建多維數組?如何使用numpy創建多維數組?Apr 29, 2025 am 12:27 AM

    使用NumPy創建多維數組可以通過以下步驟實現:1)使用numpy.array()函數創建數組,例如np.array([[1,2,3],[4,5,6]])創建2D數組;2)使用np.zeros(),np.ones(),np.random.random()等函數創建特定值填充的數組;3)理解數組的shape和size屬性,確保子數組長度一致,避免錯誤;4)使用np.reshape()函數改變數組形狀;5)注意內存使用,確保代碼清晰高效。

    說明Numpy陣列中'廣播”的概念。說明Numpy陣列中'廣播”的概念。Apr 29, 2025 am 12:23 AM

    播放innumpyisamethodtoperformoperationsonArraySofDifferentsHapesbyAutapityallate AligningThem.itSimplifififiesCode,增強可讀性,和Boostsperformance.Shere'shore'showitworks:1)較小的ArraySaraySaraysAraySaraySaraySaraySarePaddedDedWiteWithOnestOmatchDimentions.2)

    說明如何在列表,Array.Array和用於數據存儲的Numpy數組之間進行選擇。說明如何在列表,Array.Array和用於數據存儲的Numpy數組之間進行選擇。Apr 29, 2025 am 12:20 AM

    forpythondataTastorage,choselistsforflexibilityWithMixedDatatypes,array.ArrayFormeMory-effficityHomogeneousnumericalData,andnumpyArraysForAdvancedNumericalComputing.listsareversareversareversareversArversatilebutlessEbutlesseftlesseftlesseftlessforefforefforefforefforefforefforefforefforefforlargenumerdataSets; arrayoffray.array.array.array.array.array.ersersamiddreddregro

    See all articles

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱工具

    SAP NetWeaver Server Adapter for Eclipse

    SAP NetWeaver Server Adapter for Eclipse

    將Eclipse與SAP NetWeaver應用伺服器整合。

    MinGW - Minimalist GNU for Windows

    MinGW - Minimalist GNU for Windows

    這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

    VSCode Windows 64位元 下載

    VSCode Windows 64位元 下載

    微軟推出的免費、功能強大的一款IDE編輯器

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    SublimeText3 英文版

    SublimeText3 英文版

    推薦:為Win版本,支援程式碼提示!