我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python怎么实现自动录入ERP系统数据

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python怎么实现自动录入ERP系统数据

本篇内容介绍了“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'<code>.*?"rows":\[(.*?)\]', 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("'", '"')  # 将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

    2.GUI开发

    gui开发相对来说比较简单,如果不想美化,Pyqt原生的插件就可以了,我这里是借用了上一个项目的经验,用仅有的知识做了一个无边框界面和适当的美化。

    • 登录

    Python怎么实现自动录入ERP系统数据

    from PyQt5.QtCore import Qtfrom PyQt5.QtGui import QColorfrom PyQt5.QtWidgets import (QFrame, QMessageBox, QGraphicsDropShadowEffect)from Ui import login_uifrom Ui.submit_ui_main import MySubmitFormfrom 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, '警告', '用户名或密码不能为空', 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_()  # 显示主界面
    • 业务操作

    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做了一个无边框界面。

    剩下的打包就不多说了,网上的教程很多,我这里用的是&mdash;D打包,用了upx压缩,改了图标,打包完整个项目有50多M。

    “Python怎么实现自动录入ERP系统数据”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    Python怎么实现自动录入ERP系统数据

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    Python怎么实现自动录入ERP系统数据

    本篇内容介绍了“Python怎么实现自动录入ERP系统数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!项目总体情况软件:Pycharm环境
    2023-07-05

    Python自动录入ERP系统数据

    这篇文章主要介绍了Python如何自动录入ERP系统数据,用Python解决Excel问题的最佳方法,文章中有详细的代码示例,需要的朋友可以参考阅读
    2023-05-15

    python怎么实现自动登录网站爬取数据

    正文本文详细介绍如何使用Python实现在自动登录网站后抓取数据。它涵盖了基础准备、建立会话、解析登录表单、准备登录数据、提交登录表单、验证登录结果和抓取数据等步骤。示例代码演示了如何自动登录网站并抓取目标数据。扩展部分还提供了处理页面重定向、验证码、AJAX调用和会话保持等挑战的技巧。通过结合这些技术,开发人员可以构建强大的自动登录脚本,从而有效地抓取网站数据。
    python怎么实现自动登录网站爬取数据
    2024-04-12

    excel怎么用宏实现自动导入数据

    要实现自动导入数据,可以使用宏来执行以下步骤:1. 打开Excel文件,按下"ALT + F11"打开VBA编辑器。2. 在VBA编辑器中,选择你要运行宏的工作簿。3. 在VBA编辑器的"插入"菜单中,选择"模块"。4. 在新建的模块中,编
    2023-09-12

    python怎么实现通讯录系统

    这篇文章主要讲解了“python怎么实现通讯录系统”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python怎么实现通讯录系统”吧!一、首先,给大家看一下这个系统的主菜单效果如下:二、步骤分
    2023-06-30

    怎么实现Windows系统开机自动启动O2Server

    本篇内容介绍了“怎么实现Windows系统开机自动启动O2Server”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、Windows系统自
    2023-06-02

    listview自动刷新数据怎么实现

    要实现ListView自动刷新数据,可以使用以下几种方法:1. 使用Handler和Runnable实现定时刷新:在Activity或Fragment中创建一个Handler对象,并在其回调方法中更新ListView的数据源,然后调用Ada
    2023-08-26

    excel怎么实现自动数据关联

    Excel可以通过使用函数或者公式来实现自动数据关联。以下是一些常用的方法:1. 使用VLOOKUP函数:VLOOKUP函数可以根据一个值在一个数据范围中查找并返回相应的值。例如,如果你有一个订单表格和一个产品表格,你可以使用VLOOKUP
    2023-09-12

    mysql自动备份数据怎么实现

    要实现MySQL自动备份数据,可以使用以下几种方法:使用MySQL提供的自带工具mysqldump命令来备份数据。可以编写一个脚本,在指定的时间点执行mysqldump命令来备份数据,并将备份文件保存在指定的目录中。使用MySQL的事件调度
    mysql自动备份数据怎么实现
    2024-04-09

    PXE怎么实现自动化部署Linux系统

    本篇内容主要讲解“PXE怎么实现自动化部署Linux系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PXE怎么实现自动化部署Linux系统”吧!背景说明在数据中心,一次几十台甚至几百台服务器上
    2023-06-22

    怎么用Python实现数据驱动的接口自动化测试

    这篇文章主要讲解了“怎么用Python实现数据驱动的接口自动化测试”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Python实现数据驱动的接口自动化测试”吧!在接口测试的过程中,很多时
    2023-06-17

    Python自动化办公之Excel数据怎么写入

    这篇文章主要介绍了Python自动化办公之Excel数据怎么写入的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python自动化办公之Excel数据怎么写入文章都会有所收获,下面我们一起来看看吧。Excel 写
    2023-06-30

    jpa自动生成数据表怎么实现

    JPA(Java Persistence API)是JavaEE的一个规范,用于简化Java应用程序与数据库之间的交互。JPA提供了一种自动生成数据表的功能,可以通过使用实体类与注解来实现。以下是实现JPA自动生成数据表的步骤:1. 添加J
    2023-10-20

    sql自动备份数据库怎么实现

    可以通过编写一个定时脚本来实现自动备份数据库。以下是一个简单的示例脚本:创建一个备份脚本(backup.sh):#!/bin/bash# 设置数据库连接信息DB_USER="your_db_user"DB_PASS="your_db_p
    sql自动备份数据库怎么实现
    2024-04-09

    postgresql数据库自动备份怎么实现

    有多种方法可以实现PostgreSQL数据库的自动备份,以下是其中一种常见的方法:编写备份脚本:可以编写一个 shell 脚本或者 Python 脚本来实现定时备份数据库的功能。通过使用 pg_dump 命令来备份数据库,并将备份文件保存在
    postgresql数据库自动备份怎么实现
    2024-04-08

    golang数据库自动迁移怎么实现

    在Go语言中,实现数据库自动迁移可以使用一些第三方库,如gorm、migrate等。下面以使用gorm库实现数据库自动迁移为例进行说明。1. 安装gorm库:使用go get命令安装gorm库。bashgo get -u gorm.io/g
    2023-10-20

    Python中怎么实现自动导入缺失的库

    本篇内容主要讲解“Python中怎么实现自动导入缺失的库”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python中怎么实现自动导入缺失的库”吧!在写 Python 项目的时候,我们可能经常会遇
    2023-06-02

    Linux系统下怎么实现远程自动备份

    本篇内容介绍了“Linux系统下怎么实现远程自动备份”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!考虑到在本机上备份数据,一旦该机器硬盘出现
    2023-06-10

    Python/MySQL怎么实现Excel文件自动处理数据功能

    今天小编给大家分享一下Python/MySQL怎么实现Excel文件自动处理数据功能的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一
    2023-07-05

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录