欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python自動錄入ERP系統(tǒng)數(shù)據(jù)

 更新時(shí)間:2023年04月10日 10:40:59   作者:畢加鎖  
這篇文章主要介紹了Python如何自動錄入ERP系統(tǒng)數(shù)據(jù),用Python解決Excel問題的最佳方法,文章中有詳細(xì)的代碼示例,需要的朋友可以參考閱讀

項(xiàng)目總體情況

軟件:Pycharm

環(huán)境: Python 3.7.9(考慮到客戶可能會有不同操作系統(tǒng),為了兼容性考慮)

技術(shù)庫: requests、pandas、Pyqt5等(詳見依賴文件)

需求分析

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

  • 根據(jù)“單號歸屬”批量向3個接口提交數(shù)據(jù)
  • 需要一個GUI操作界面
  • 支持不同的業(yè)務(wù)員登錄

總的來說就是一個POST數(shù)據(jù)提交和GUI開發(fā)。

項(xiàng)目實(shí)施

1.Post提交

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

1.1登錄

通過抓包發(fā)現(xiàn),密碼是明文,難度就降低了一半,然后用正確的密碼再分析登錄成功后的返回。

    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

發(fā)現(xiàn)登錄成功后會返回一個“IDENTIFIER”參數(shù),值是加密字符串,這樣就很明顯,光看字面意思都知道這個肯定有用,所以先記錄下來。

1.2接口分析

由于我用的是測試賬號,這個賬號提交的數(shù)據(jù)都要刪掉,為了不給別人注入太多的無效數(shù)據(jù),這里就不再實(shí)際錄入,以業(yè)務(wù)代碼來說明。

  • 獲取車輛信息

通過分析發(fā)現(xiàn),雖然客戶給了一部分車輛的信息,但是還有多缺失的信息,需要自己補(bǔ)充。通過抓包發(fā)現(xiàn),在輸入車輛編號以后,會發(fā)起一個Ajax請求,表單里其他信息就是Ajax請求返回的數(shù)據(jù)。

 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
  • 獲取人員信息

表單的人員信息我通過抓包沒有發(fā)現(xiàn),后來再一個頁面中找到了相關(guān)的數(shù)據(jù)。

這里稍微麻煩一點(diǎn),需要用正則把數(shù)據(jù)匹配出來。

    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
  • 發(fā)起請求,提交數(shù)據(jù)

拿到了登錄返回的標(biāo)識符、車輛信息、人員信息,剩下的就是和客戶給的數(shù)據(jù)結(jié)合起來,發(fā)起請求。需要注意的是,請求參數(shù)需要轉(zhuǎn)為url編碼,請求參數(shù)也是這個爬蟲里面最麻煩的部分,這里給大家展示一個請求需要發(fā)送的參數(shù)。

參數(shù)多,格式要求也比較嚴(yán)格,整個開發(fā)過程,這里調(diào)試花費(fèi)的時(shí)間也最長。調(diào)試完正常應(yīng)該是把代碼簡化一下,該合并的合并,我調(diào)試好了以后懶得再去改了,所以這一塊寫的比較冗余。

    def submit_data(self, i: dict, IDENTIFIER: str):
        """
        眾意數(shù)據(jù)提交
        """
        personal_info = self.get_personal_info(IDENTIFIER)  # 獲取個人信息
        personal_info_data = str(personal_info).replace("'", '"')  # 將personal_info轉(zhuǎn)換為字符串
        url = "http://cloud.tiamaes.com:11349/money/money.action/CharteredAction/saveForm.do"
        print(f'開始處理--{i["單號歸屬"]}--數(shù)據(jù)')
        memo = f'工單號{i["工單號"]}、餐費(fèi){i["餐費(fèi)"]}、住宿{i["住宿"]}、過路過橋費(fèi){i["過路過橋費(fèi)"]}、油費(fèi){i["油費(fèi)"]}、備注{i["備注"]}'  # 拼接備注信息
        car_infos = self.get_car_details(str(i["車號"]), IDENTIFIER)  # 獲取車輛信息
        pay_type = {
            "現(xiàn)金": "3",
            "轉(zhuǎn)賬": "2",
            "欠款": "1"
        }
        single_and_double = {
            "單程": "1",
            "雙程": "2"
        }
        colType = pay_type[i["結(jié)賬方式"]]  # 獲取結(jié)賬方式編碼
        oddEven = single_and_double[i["單雙程"]]  # 獲取單雙程編碼
        now_date = datetime.datetime.now().date().strftime("%Y-%m-%d")  # 獲取當(dāng)前日期
        .......(此處省略)
        data["_tp_data"] = data["_tp_data"].replace('"dsName":"83"', '"dsName":"82"')
        data = parse.urlencode(data).replace("+", "")  # 將字典轉(zhuǎn)換成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開發(fā)

gui開發(fā)相對來說比較簡單,如果不想美化,Pyqt原生的插件就可以了,我這里是借用了上一個項(xiàng)目的經(jīng)驗(yàn),用僅有的知識做了一個無邊框界面和適當(dāng)?shù)拿阑?/p>

  • 登錄

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
        # 設(shè)置無邊框模式
        self.setWindowFlag(Qt.FramelessWindowHint)  # 將界面設(shè)置為無框
        self.setAttribute(Qt.WA_TranslucentBackground)  # 將界面屬性設(shè)置為半透明
        self.shadow = QGraphicsDropShadowEffect()  # 設(shè)定一個陰影,半徑為10,顏色為#444444,定位為0,0
        self.shadow.setBlurRadius(10)
        self.shadow.setColor(QColor("#444444"))
        self.shadow.setOffset(0, 0)
        self.frame.setGraphicsEffect(self.shadow)  # 為frame設(shè)定陰影效果
        # ------------------------------------------------
        self.show()
        self.pushButton_3.clicked.connect(self.close)  # 關(guān)閉按鈕
        self.pushButton_login.clicked.connect(self.do_login)  # 登錄按鈕
 
    # 以下是控制窗口移動的代碼
    def mousePressEvent(self, event):  # 鼠標(biāo)左鍵按下時(shí)獲取鼠標(biāo)坐標(biāo),按下右鍵取消
        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):  # 鼠標(biāo)在按下左鍵的情況下移動時(shí),根據(jù)坐標(biāo)移動界面
        if Qt.LeftButton and self.m_flag:
            self.move(QMouseEvent.globalPos() - self.m_Position)
            QMouseEvent.accept()
 
    def mouseReleaseEvent(self, QMouseEvent):  # 鼠標(biāo)按鍵釋放時(shí),取消移動
        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, '警告', '用戶名或密碼不能為空', QMessageBox.Yes)
            return
        else:
            IDENTIFIER = self.submit.login(username, password)
            if not IDENTIFIER:
                QMessageBox.warning(self, '警告', '用戶名或密碼錯誤', QMessageBox.Yes)
                return
            self.hide()  # 隱藏登錄界面
            my_submit_form = MySubmitForm(self.submit, IDENTIFIER)
            my_submit_form.exec_()  # 顯示主界面
  • 業(yè)務(wù)操作

class MySubmitForm(submitform_ui.Ui_Dialog_Submit, QDialog):
    def __init__(self, submit: TransitSubmit, IDENTIFIER: str):
        super().__init__()
        ......
        self.setupUi(self)
        ......
        self.progressBar.hide()  # 關(guān)閉進(jìn)度條顯示
        self.setWindowFlags(Qt.FramelessWindowHint)  # 無邊框
        self.setAttribute(Qt.WA_TranslucentBackground)  # 設(shè)置窗口透明
        self.pushButton_mini.clicked.connect(self.showMinimized)  # 實(shí)現(xiàn)最小化
        self.pushButton_close.clicked.connect(self.close)  # 實(shí)現(xiàn)關(guān)閉功能
        ......
        self.show()
 
    # 實(shí)現(xiàn)鼠標(biāo)拖拽功能
    def mousePressEvent(self, event):
        self.pressX = event.x()  # 記錄鼠標(biāo)按下的時(shí)候的坐標(biāo)
        self.pressY = event.y()
 
    def mouseMoveEvent(self, event):
        x = event.x()
        y = event.y()  # 獲取移動后的坐標(biāo)
        moveX = x - self.pressX
        moveY = y - self.pressY  # 計(jì)算移動了多少
        positionX = self.frameGeometry().x() + moveX
        positionY = self.frameGeometry().y() + moveY  # 計(jì)算移動后主窗口在桌面的位置
        self.move(positionX, positionY)  # 移動主窗口
    ......

這里多說一嘴,最開始這里我用的和登錄一樣,使用的是QFrame,但是它沒有exec()方法,登錄成功后不能彈出,也可能是我知識有限,做不出來。通過分析源碼,發(fā)現(xiàn)QDialog有這個方法,可以實(shí)現(xiàn)彈出,后來又改了用QDialog做了一個無邊框界面。

剩下的打包就不多說了,網(wǎng)上的教程很多,我這里用的是—D打包,用了upx壓縮,改了圖標(biāo),打包完整個項(xiàng)目有50多M。

寫在最后

總的來說,這個項(xiàng)目代碼寫的一般,基本上以實(shí)用為主,沒有做太多的封裝和優(yōu)化,反正客戶也不要源碼,只要項(xiàng)目能跑起來就萬事大吉了。

以上就是Python自動錄入ERP系統(tǒng)數(shù)據(jù)的詳細(xì)內(nèi)容,更多關(guān)于Python錄入ERP系統(tǒng)數(shù)據(jù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python中mediapipe庫踩過的坑實(shí)戰(zhàn)記錄

    python中mediapipe庫踩過的坑實(shí)戰(zhàn)記錄

    MediaPipe是由google制作的開源的、跨平臺的機(jī)器學(xué)習(xí)框架,可以將一些模型部署到不同的平臺和設(shè)備上使用的同時(shí),也能保住檢測速度,下面這篇文章主要給大家介紹了關(guān)于python中mediapipe庫踩過的坑的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • python文本數(shù)據(jù)處理學(xué)習(xí)筆記詳解

    python文本數(shù)據(jù)處理學(xué)習(xí)筆記詳解

    這篇文章主要為大家詳細(xì)介紹了python文本數(shù)據(jù)處理學(xué)習(xí)筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • python?memory_profiler庫生成器和迭代器內(nèi)存占用的時(shí)間分析

    python?memory_profiler庫生成器和迭代器內(nèi)存占用的時(shí)間分析

    這篇文章主要介紹了python?memory_profiler庫生成器和迭代器內(nèi)存占用的時(shí)間分析,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,感興趣的小伙伴可以參考一下
    2022-06-06
  • 關(guān)于Python中字典dict的存儲原理詳解

    關(guān)于Python中字典dict的存儲原理詳解

    Python字典是另一種可變?nèi)萜髂P?可存儲任意類型對象。如字符串、數(shù)字、元組等其他容器模型,因?yàn)樽值涫菬o序的所以不支持索引和切片,需要的朋友可以參考下
    2023-05-05
  • python實(shí)現(xiàn)滑動拼圖驗(yàn)證碼擺脫煩人的驗(yàn)證碼輸入

    python實(shí)現(xiàn)滑動拼圖驗(yàn)證碼擺脫煩人的驗(yàn)證碼輸入

    這篇文章主要為大家介紹了python實(shí)現(xiàn)滑動拼圖驗(yàn)證碼擺脫煩人的驗(yàn)證碼輸入方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • 解決seaborn在pycharm中繪圖不出圖的問題

    解決seaborn在pycharm中繪圖不出圖的問題

    今天小編就為大家分享一篇解決seaborn在pycharm中繪圖不出圖的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Python 中如何實(shí)現(xiàn)參數(shù)化測試的方法示例

    Python 中如何實(shí)現(xiàn)參數(shù)化測試的方法示例

    這篇文章主要介紹了Python 中如何實(shí)現(xiàn)參數(shù)化測試的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • python 下載文件的多種方法匯總

    python 下載文件的多種方法匯總

    這篇文章主要介紹了python 下載文件的多種方法匯總,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-11-11
  • python optparse模塊使用實(shí)例

    python optparse模塊使用實(shí)例

    這篇文章主要介紹了python optparse模塊使用實(shí)例,optparse是專門來處理命令行選項(xiàng)的,本文就講解了它的使用方法,需要的朋友可以參考下
    2015-04-04
  • 人臉識別具體案例(李智恩)

    人臉識別具體案例(李智恩)

    出于興趣和對IU的喜愛,筆者花了幾天嘗試用爬蟲從百度圖片獲取韓國藝人的人物圖片并下載,利用深度神經(jīng)網(wǎng)絡(luò)從其中識別出IU(李知恩),并將IU的人物圖片保存至文件夾。若讀者有興趣可以參考下
    2021-04-04

最新評論