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)
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.
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.
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
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.
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.
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.
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'<code>.*?"rows":\[(.*?)\]', 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.
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("'", '"') # 将personal_info转换为字符串 url = "http://cloud.tiamaes.com:11349/money/money.action/CharteredAction/saveForm.do" print(f'开始处理--{i["单号归属"]}--数据') memo = f'工单号{i["工单号"]}、餐费{i["餐费"]}、住宿{i["住宿"]}、过路过桥费{i["过路过桥费"]}、油费{i["油费"]}、备注{i["备注"]}' # 拼接备注信息 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('"dsName":"83"', '"dsName":"82"') 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
Ü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!