Heim  >  Artikel  >  Backend-Entwicklung  >  So geben Sie ERP-Systemdaten automatisch in Python ein

So geben Sie ERP-Systemdaten automatisch in Python ein

PHPz
PHPznach vorne
2023-05-10 12:52:061969Durchsuche

    Gesamtprojektsituation

    Software: Pycharm

    Umgebung: Python 3.7.9 (unter Berücksichtigung, dass Kunden aus Kompatibilitätsgründen möglicherweise unterschiedliche Betriebssysteme haben)

    Technische Bibliothek: Anfragen, Pandas, Pyqt5 usw. (Einzelheiten finden Sie in den Abhängigkeitsdateien)

    Anforderungsanalyse

    Durch Analyse und Kommunikation mit Kundennachfragedokumenten ergeben sich ungefähr die folgenden Anforderungen:

    • Daten stapelweise an 3 Schnittstellen gemäß „ungerade“ senden Nummernzuordnung"

    • Benötigt eine GUI-Bedienoberfläche

    • Unterstützen Sie verschiedene Verkäufer beim Anmelden

    Im Allgemeinen handelt es sich um eine POST-Datenübermittlung und GUI-Entwicklung.

    Projektimplementierung

    1.Post-Einreichung

    In diesem Abschnitt wird hauptsächlich die Crawler-Technologie verwendet. Die Schritte, die seit Tausenden von Jahren unverändert bleiben, bestehen darin, zunächst die Webseite zu analysieren.

    1.1 Anmeldung

    So geben Sie ERP-Systemdaten automatisch in Python ein

    Durch die Paketerfassung wird festgestellt, dass das Passwort Klartext ist, was die Schwierigkeit um die Hälfte reduziert. Verwenden Sie dann das richtige Passwort, um die Rückgabe nach erfolgreicher Anmeldung zu analysieren.

        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

    So geben Sie ERP-Systemdaten automatisch in Python ein

    Ich habe festgestellt, dass nach erfolgreicher Anmeldung ein „IDENTIFIER“-Parameter zurückgegeben wird und der Wert eine verschlüsselte Zeichenfolge ist. Das ist offensichtlich, dass dies nützlich sein muss. Also nimm es zuerst auf.

    1.2 Schnittstellenanalyse

    Da ich ein Testkonto verwende, werden die von diesem Konto übermittelten Daten gelöscht, um nicht zu viele ungültige Daten in andere einzuschleusen, der eigentliche Eintrag erfolgt hier nicht und der Geschäftscode wird nicht berücksichtigt wird zur Veranschaulichung herangezogen.

    • Fahrzeuginformationen abrufen

    Durch die Analyse wurde festgestellt, dass der Kunde zwar einen Teil der Fahrzeuginformationen bereitgestellt hat, jedoch noch viele Informationen fehlten, die selbst ergänzt werden mussten. Durch die Paketerfassung haben wir festgestellt, dass nach Eingabe der Fahrzeugnummer eine Ajax-Anfrage initiiert wird und die anderen Informationen im Formular die von der Ajax-Anfrage zurückgegebenen Daten sind.

    So geben Sie ERP-Systemdaten automatisch in Python ein

     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
    • Personalinformationen abrufen

    Ich habe die Personalinformationen im Formular nicht über die Paketerfassung gefunden, habe die relevanten Daten aber später auf einer anderen Seite gefunden.

    So geben Sie ERP-Systemdaten automatisch in Python ein

    Das ist etwas schwieriger. Sie müssen reguläre Ausdrücke verwenden, um die Daten abzugleichen.

        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
    • Eine Anfrage starten und Daten übermitteln

    Holen Sie sich die vom Login zurückgegebenen Kennungen, Fahrzeuginformationen und Personalinformationen. Der Rest besteht darin, diese mit den vom Kunden angegebenen Daten zu kombinieren, um die Anfrage zu initiieren. Es ist zu beachten, dass die Anfrageparameter in die URL-Kodierung umgewandelt werden müssen. Die Anfrageparameter sind auch der problematischste Teil dieses Crawlers. Hier zeigen wir Ihnen die Parameter, die in einer Anfrage gesendet werden müssen.

    So geben Sie ERP-Systemdaten automatisch in Python ein

    Es gibt viele Parameter und die Formatanforderungen sind relativ streng. Im gesamten Entwicklungsprozess dauert das Debuggen hier auch am längsten. Nach dem Debuggen sollte der Code vereinfacht werden, um die Zusammenführung zu ändern, die nach dem Debuggen zusammengeführt werden muss, daher ist dieser Abschnitt relativ überflüssig.

        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-Entwicklung ist relativ einfach. Wenn Sie es nicht verschönern möchten, reicht das native Plug-in von Pyqt aus. Hier habe ich mir die Erfahrung des vorherigen Projekts ausgeliehen und mein einziges Wissen verwendet grenzenlose Schnittstelle und richtige Verschönerung. „Anmelden“ exec()-Methode kann nach erfolgreicher Anmeldung nicht angezeigt werden. Möglicherweise sind meine Kenntnisse begrenzt und ich kann dies nicht tun. Durch die Analyse des Quellcodes habe ich festgestellt, dass QDialog über diese Methode verfügt, um ein Popup zu erreichen. Später habe ich sie geändert und QDialog verwendet, um eine randlose Schnittstelle zu erstellen.

    Über den Rest der Verpackung werde ich nicht viel sagen. Es gibt viele Tutorials im Internet, die ich hier verwende, nämlich D-Verpackung, UpX-Komprimierung und geänderte Symbole.

    Das obige ist der detaillierte Inhalt vonSo geben Sie ERP-Systemdaten automatisch in Python ein. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Stellungnahme:
    Dieser Artikel ist reproduziert unter:yisu.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen