前言

之前整了一个GZY.EFCoreCompare 的库,可以用做对比实体与数据库结构.感兴趣可以去看看,地址:GZY.EFCoreCompare

但是只能导出execl表格.

后来大佬用Python写了个类,可以将execl表格直接生成SQL语句.  但是需要通过开发工具 或者python环境去运行.

对现场的非技术人员很不友好..所以就想着用WinForm包装一个UI界面.

废话不多说,我们开始正文

正文

.NET Core目前主流的和python交互的类库有两个. CSnakes 和 Python.NET

我是两个类库都试过了,虽然CSnakes性能可能更好,但是需要采用依赖注入的形式去使用,

而且虚拟环境需要科技上网才能下载,对WinForm并不太友好,所以后来放弃了.

Python.NET则可以直接使用嵌入式的python版本来作为环境,相对WinForm比较友好,所以这里采用Python.NET来与python进行交互

1.下载嵌入式的python

2.处理嵌入式的python无法使用pip的问题

  • 解压后编辑 python313._pth (这里是3.13版本,根据版本编辑),取消注释 import site
  • 下载 https://bootstrap.pypa.io/pip/get-pip.py 到python.exe所在文件夹
  • 执行命令: 
    .\python.exe get-pip.py
  • 然后执行命令:
    .\python.exe -m pip

    这样,我们就发现pip可以正常使用了

3.通过pip命令下载所需的包.

我这里因为使用的pandas解析的excel所以需要安装pandas,命令如下:

.\python.exe -m pip install --upgrade pandas -t Lib\site-packages\
.\python.exe -m pip install --upgrade openpyxl -t Lib\site-packages\

这里我们通过-t 指定下载到嵌入式python的相对文件夹下,方便我们打包

4.将安装好包的python目录复制到Winfrom项目下,并设置复制到输出目录.

类似如图:

5.通过Nuget安装Python.NET包.

如图:

6.编写WinFrom加载和点击事件

这里就不贴其他控件了,没啥内容.

我们在窗体加载的时候初始化python的环境,代码如下:

 private void AdminForm_Load(object sender, EventArgs e)
{ string pythonPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "pythone");
string pythonDll = Path.Combine(pythonPath, "python313.dll");
Runtime.PythonDLL = pythonDll;
PythonEngine.Initialize(); }

在按钮点击的时候,调用python类,去生成对应的SQL语句,代码如下:

        private void button2_Click(object sender, EventArgs e)
{
if (string.IsNullOrEmpty(textBox1.Text))
{
MessageBox.Show("请选择文件!");
return;
} using (Py.GIL())
{
dynamic sys = Py.Import("sys"); //导入sys模块
string sitePackagesPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "pythone", "Lib", "site-packages"); //设置site-packages路径
string scripts= Path.Combine(AppDomain.CurrentDomain.BaseDirectory);//设置python脚本所在路径
sys.path.append(sitePackagesPath);//添加site-packages路径
sys.path.append(scripts);//添加python脚本路径
dynamic np = Py.Import("gen_sql_fromexcel"); //导入python脚本 np.generate_sql_from_excel(textBox1.Text, Environment.CurrentDirectory + "/output.sql"); //调用python脚本中的方法 }
MessageBox.Show("生成成功!请到根目录查看."); }

注释里已经解释了对应代码的作用.(注意,一定要设置依赖包的路径  也就是site-packages路径的)

这样就完成了整个调用的过程.

.NET Core奇技淫巧之WinForm使用Python.NET并打包的更多相关文章

  1. c# winform UI + python底层的一点尝试

    鉴于python做winform之类的UI比较弱.于是想结合C#的winform 和 python的底层开发(windows平台). 尝试做了一个RSS阅读器.在这里:http://download. ...

  2. python开发环境配置和python源码打包生成exe可执行文件

    Windows下开发环境准备 1.分别安装:python2和python32.安装Python的集成工具:Anaconda3.安装Pycharm Pycharm设置 设置: File->Sett ...

  3. python模块的打包

    python模块的打包方法: http://blog.csdn.net/five3/article/details/7847551

  4. Python Windows下打包成exe文件

    Python Windows 下打包成exe文件,使用PyInstaller 软件环境: 1.OS:Win10 64 位 2.Python 3.7 3.安装PyInstaller 先检查是否已安装Py ...

  5. Python服务Debian打包新思路

    此文已由作者张耕源授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. Debian 打包一直是比较冷僻的技术,大部分同学都不会接触到它. 但是我们 Debian 服务器上安装的各 ...

  6. Python selenium chrome打包exe后禁用控制台输出滚动日志

    Python selenium chrome打包exe后,在运行的过程中,如果遇到需要input()输入时,会发现被不断滚动刷新的日志把命令行输入快速顶掉了,通过查阅资料不断实践,发现以下方法有效: ...

  7. ASP.NET Core 奇技淫巧之接口代理转发

    前言 先讲讲本文的开发背景吧.. 在如今前后端分离的大背景下,咱的客户又有要求啦~ 要前后端分离~ 然因为种种原因..没办法用用纯前端的框架(其实是学习成本高,又没钱请前端开发人员)... 所以最终决 ...

  8. python模块的打包setuptools

    样例代码:新建test.py文件,内容如下: print "show me" 新建一个setup.py编译文件,内容如下: from distutils.core import s ...

  9. Python学习笔记(一):Python代码的打包与发布

    在python程序中,一个.py文件被当作一个模块,在各个模块中定义了不同的函数.当我们要使用某一个模块中的某一个函数时,首先须将这个模块导入,否则就会出现函数未定义的情况. 下面记录的是打包及安装包 ...

  10. python下py2exe打包笔记

    1.下载与python版本一致的py2exe插件包 2.安装py2exe,安装后在python目录下存在:\Lib\site-packages\py2exe\... 3.新建一个python脚本文件, ...

随机推荐

  1. Android-studio-ide-201.7042882-windows-4.1.2项目卡在Gradle: Download gradle-6.5-bin.zip

    现象描述: Android-studio-ide-201.7042882-windows-4.1.2项目卡在Gradle: Download gradle-6.5-bin.zip,如下所示: 原因分析 ...

  2. [转]C#的二进制文件操作及关于Encoding类与汉字编码转换的问题

    1.数值应保存在二进制文件 首先列举文本.二进制文件的操作(读写)方法: 方式1: //文本文件操作:创建/读取/拷贝/删除 using System; using System.IO; class ...

  3. Python多分类Logistic回归详解与实践

    在机器学习中,Logistic回归是一种基本但非常有效的分类算法.它不仅可以用于二分类问题,还可以扩展应用于多分类问题.本文将详细介绍如何使用Python实现一个多分类的Logistic回归模型,并给 ...

  4. 优化博客Ⅰ-压缩图片为webp格式

    自动压缩博客图片为webp格式 作为自己的个人博客,我非常喜欢搞一些花里胡哨的东西,其中就包括不少精美图片,但是过多的图片会占用大量的网络资源导致博客加载速度变慢. 那怎么办呢? 第一个想到的就是升级 ...

  5. GRPC-JAVA

    近一年来一直在用公司内wiki进行技术调研以及记录,后期有时间将逐步迁移至博客园 参考资料: https://github.com/grpc/grpc-java https://www.cnblogs ...

  6. Mac 下erlang及rabbitmq安装

    --------------------------------------- 1.首先,安装Homebrew安装Homebrew遇到的问题参考这个链接 2.安装erlang环境brew instal ...

  7. RockyLinux9编译安装MySQL5.7

    Linux版本: Rocky Linux release 9.5 (Blue Onyx) 1.下载 打开MySQL-Community-Server官方下载页面:https://downloads.m ...

  8. 【译】MongoDB EF Core 提供程序:有什么新功能?

    原文 | Rishit, Luce 翻译 | 郑子铭 这是 Rishit Bhatia 和 Luce Carter 的客座文章.Rishit 是 MongoDB 的高级产品经理,专注于 .NET 开发 ...

  9. verilog 编写猫狗过河实验

    源代码地址:https://github.com/penggeon/catanddog 效果演示见: https://www.bilibili.com/video/BV1n24y147S1 警告: 仅 ...

  10. 爬虫基础知识及scrapy框架使用和基本原理

    爬虫 一.异步IO 线程:线程是计算机中工作的最小单元 ​ IO请求(IO密集型)时多线程更好,计算密集型进程并发最好,IO请求不涉及CPU 自定义线程池 进程:进程默认有主线程,可以有多线程共存,并 ...