Revit二次开发 将构件信息导入到数据库中

revit中构件数据量较大,在做标准化或者审核软件的时候需要用到数据库,将数据导入数据库使得计算能够脱离软件进行计算也算是一种另类的软件减负

demo

  1. 获取构件-测试项目随便框选几个构件进行输出数据

    UIDocument uidoc = commandData.Application.ActiveUIDocument;
            Document doc = uidoc.Document;
            var refer = uidoc.Selection.PickObjects(ObjectType.Element, "pick onjects");
            List<string> categorys = new List<string>();
            List<int> elementIds = new List<int>();
            List<string> symbolNames = new List<string>();
            foreach(Reference re in refer)
            {
                Element e = doc.GetElement(re);
                string symbolName = e.Name;
                string category = e.Category.Name;
                int elementId = e.Id.IntegerValue;
                symbolNames.Add(symbolName);
                categorys.Add(category);
                elementIds.Add(elementId);
    
            }
    
  2. 连接数据库

  • 因为是测试所以将mysql连接设置为本地连接,这一步应该是创建Mysql文件传递到服务器数据库中进行读取
 public MySQLConnection2(List<int> elementids,List<string> symbolNames,List<string> categorys)
        {
            MySqlConnection conn;
            string myConnectionString;
            myConnectionString = "server=localhost;uid=root;password=*****;port=3306;database=test01";
            try
            {
                conn = new MySqlConnection();
                conn.ConnectionString = myConnectionString;
                conn.Open();
                string command = SetData("revitDatas", elementids, symbolNames, categorys);
                MySqlCommand cmd = new MySqlCommand(command,conn);
                cmd.ExecuteNonQuery();
                conn.Close();
            }
            catch (Exception ex)
            {
                TaskDialog.Show("MysqlError",ex.Message);
            }
        }
  1. 在form中显示 前端代码相对简单将数据流传入即可

            string myConnectionString;
            myConnectionString = "server=localhost;uid=root;password=*****;port=3306;database=test01";
            MySql.Data.MySqlClient.MySqlConnection conn = new MySql.Data.MySqlClient.MySqlConnection(myConnectionString);
            conn.Open();
            string cmd = "SELECT * FROM revitDatas";
            MySql.Data.MySqlClient.MySqlCommand mscmd = new MySql.Data.MySqlClient.MySqlCommand(cmd, conn);
            MySql.Data.MySqlClient.MySqlDataAdapter adpter = new MySql.Data.MySqlClient.MySqlDataAdapter(mscmd);
            DataTable table = new DataTable();
            adpter.Fill(table);
            dataGridView1.DataSource = table;
            conn.Close();
            conn.Dispose();

在这里插入图片描述
到这一步便可以将数据提取进行利用,但是前端这块datagrid会出现空行或者空列,需要设置一下参数
dataGridView1.AllowUserToAddRows = false;将值改为false即可。参考链接:https://blog.csdn.net/wanglejun/article/details/39231075
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值