百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

通过Git实现对西门子博图程序版本控制

wptr33 2025-02-15 17:38 15 浏览

  1. 背景

在工业自动化项目调试过程中,经常会出现程序部分代码使用迭代更新、回滚等需求,时间久远后,经常会发生,不知那个版本才是自己需要的版本,git管理工具可以满足工程师们这个需求。

  1. 概述

通过博图版本控制接口VCI,可以将开源式分布式控制系统Git连接的计算机博图软件中。

可以实现对FB/FC/DB/软件单元等实现版本管理。

  1. 软件需求
  2. 博图V16
  3. Git软件 Git-2.47.1-64-bit(根据自身计算机系统版本确定)
  4. 远程仓库https://gitee.com 注册账户
  5. 实现步骤

4.1下载git软件及博图插件
TIA_Add-In_VCI_Git_Connector_1.0.0

下载网址:

a)https://support.industry.siemens.com/cs/document/109773999/tia-add-in?dti=0&lc=zh-CN

b)https://git-scm.com/downloads

4.2 安装

a) 将
Siemens.VCIGitConnector.addin 放入到 博途安装路径 AddIns 中,

默认是 C:\Program Files\Siemens\Automation\Portal V16\AddIns 文件夹中.

b) Git-2.47.1-64-bit,右键,选择“以管理员身份运行”。

4.3激活博图VCI 插件

开启博图新建事例项目,鼠标左键单击软件右侧“插件”。

鼠标选择“
Siemens.VciGitConnect.addin”,左键单击“状态”列箭头,选择“激活”。激活后如下图所示:

  • 在计算机L盘新建文件夹,例如文件夹名称 “L:\Private\gitProTest”,此文件夹作为本地仓库存储程序文件用途。右键单击gitProTest,选择“Open Git Bash here”.弹出下图所示


  • 本地仓库初始化及仓库配置
  1. 输入git init,执行仓库初始化。

2)git config --global user.name "anum" #配置用户名为 anum

git config --global user.email "123@qq.com" #配置邮箱信息为 123@qq.com

3)查看仓库状态 输入git status

  • 博图软件端程序代码执行推入本地仓库及远程仓库操作
  1. 在工程树管理窗口—>版本控制接口下,新建工作区,并打开工作区。
  2. 工作区配置:工作区路径选择刚新建的文件夹gitProTest,版本控制插件选择Git.

单击弹出窗口的 “确定”按钮。

  1. 将所需控制的程序FB/FC/DT鼠标左键选择后拖拽到右侧工作区,本例以“FB2000_Motor”为例,如下图所示:

输入注释后,单击OK按钮,执行完成后弹出如下窗口。

  1. 将FB2000_Motor修改,删除输入变量“i_bEnable”,重新编译。

此刻注意,版本控制接口之工作区已经发生变化。

动作:选择 “->导出到工作区”,动作图标再次发生变化。

选择顶部 “同步”按钮。

弹出注释输入窗口,对新变更做备注,单击“OK”按钮。

(5)查看本地仓库文件存储状态

从上图可以看出,仓库存在2个版本,V1.0.0 和V1.1.0. 文件资源管理器中,可以看见FB已经在仓库中了。

  • 远程仓库端操作
  1. 在https://gitee.com/注册账户并登录,然后新建仓库。
  2. 在本地仓库“Open Git Bash here”窗口实现本地仓库与远程仓库关联。

git remote add origin https://gitee.com/XXXX-lukas/portal-vci.git 将本地仓库与一个远程仓库关联起来。origin 是远程仓库在本地的默认名称,用于指代名称后面的远程仓库地址,也可以用其它名字。XXXX-lukas/portal-vci.git为远程仓库名称。

  1. 输入git remote –v查看关联状态
  • 将本地仓库中文件推入远程仓库中。

工作区右键选择带推入的文件,选择Git –>Push.

推送完成后,弹出如下界面。

查看远程仓库:

4.10 版本回滚操作

经过FB修改,现在本地仓库有2个版本的文件,其中一个是普通A,没有使能信号及清除数据信号,另一个版本B添加了使能信号及清除运行数据信号。

  1. 使用git reflog 查看对应版本号

HEAD@{0}:最新版本

HEAD@{1}:之前版本

  1. 例如我们需要回滚到之前的版本,使用git reset --hard HEAD @{1} #回滚版本

其中的 1 就是 reflog 中显示的版本号。

在图中, 1 是第一版, 0 是第二版。

如果新增第三版。那 2 就会指向第一版, 0 指向第三版。

博图版本控制接口-工作区,变化如下图所示:

动作选择:从工作区导入 –> 单击顶部 “同步”按钮。PLC程序更新完成。

  • 远程仓库推送到本地仓库

后期如果其它项目需要使用该远程仓库程序文件,可以同样建立本地仓库文件,然后初始化->本地仓库配置用户名和邮箱 ->关联远程仓库,然后再博图版本控制接口-工作区,右键选择.Vci,选择pull. 这操作就可以实现将远程仓库pull到本地仓库。

完成后弹出如下所示:

如果发生报错,则需要在本地仓库文件下,右键选择git bash here.输入指令:git pull origin master.

相关推荐

每天一个编程技巧!掌握这7个神技,代码效率飙升200%

“同事6点下班,你却为改BUG加班到凌晨?不是你不努力,而是没掌握‘偷懒’的艺术!本文揭秘谷歌工程师私藏的7个编程神技,每天1分钟,让你的代码从‘能用’变‘逆天’。文末附《Python高效代码模板》,...

Git重置到某个历史节点(Sourcetree工具)

前言Sourcetree回滚提交和重置当前分支到此次提交的区别?回滚提交是指将改动的代码提交到本地仓库,但未推送到远端仓库的时候。...

git工作区、暂存区、本地仓库、远程仓库的区别和联系

很多程序员天天写代码,提交代码,拉取代码,对git操作非常熟练,但是对git的原理并不甚了解,借助豆包AI,写个文章总结一下。Git的四个核心区域(工作区、暂存区、本地仓库、远程仓库)是版本控制的核...

解锁人生新剧本的密钥:学会让往事退场

开篇:敦煌莫高窟的千年启示在莫高窟321窟的《降魔变》壁画前,讲解员指着斑驳色彩说:"画师刻意保留了历代修补痕迹,因为真正的传承不是定格,而是流动。"就像我们的人生剧本,精彩章节永远...

Reset local repository branch to be just like remote repository HEAD

技术背景在使用Git进行版本控制时,有时会遇到本地分支与远程分支不一致的情况。可能是因为误操作、多人协作时远程分支被更新等原因。这时就需要将本地分支重置为与远程分支的...

Git恢复至之前版本(git恢复到pull之前的版本)

让程序回到提交前的样子:两种解决方法:回退(reset)、反做(revert)方法一:gitreset...

如何将文件重置或回退到特定版本(怎么让文件回到初始状态)

技术背景在使用Git进行版本控制时,经常会遇到需要将文件回退到特定版本的情况。可能是因为当前版本出现了错误,或者想要恢复到之前某个稳定的版本。Git提供了多种方式来实现这一需求。...

git如何正确回滚代码(git命令回滚代码)

方法一,删除远程分支再提交①首先两步保证当前工作区是干净的,并且和远程分支代码一致$gitcocurrentBranch$gitpullorigincurrentBranch$gi...

[git]撤销的相关命令:reset、revert、checkout

基本概念如果不清晰上面的四个概念,请查看廖老师的git教程这里我多说几句:最开始我使用git的时候,我并不明白我为什么写完代码要用git的一些列指令把我的修改存起来。后来用多了,也就明白了为什么。gi...

利用shell脚本将Mysql错误日志保存到数据库中

说明:利用shell脚本将MYSQL的错误日志提取并保存到数据库中步骤:1)创建数据库,创建表CreatedatabaseMysqlCenter;UseMysqlCenter;CREATET...

MySQL 9.3 引入增强的JavaScript支持

MySQL,这一广泛采用的开源关系型数据库管理系统(RDBMS),发布了其9.x系列的第三个更新版本——9.3版,带来了多项新功能。...

python 连接 mysql 数据库(python连接MySQL数据库案例)

用PyMySQL包来连接Python和MySQL。在使用前需要先通过pip来安装PyMySQL包:在windows系统中打开cmd,输入pipinstallPyMySQL ...

mysql导入导出命令(mysql 导入命令)

mysql导入导出命令mysqldump命令的输入是在bin目录下.1.导出整个数据库  mysqldump-u用户名-p数据库名>导出的文件名  mysqldump-uw...

MySQL-SQL介绍(mysql sqlyog)

介绍结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以使用相同...

MySQL 误删除数据恢复全攻略:基于 Binlog 的实战指南

在MySQL的世界里,二进制日志(Binlog)就是我们的"时光机"。它默默记录着数据库的每一个重要变更,就像一位忠实的史官,为我们在数据灾难中提供最后的救命稻草。本文将带您深入掌握如...