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
在这里插入图片描述

  • 0
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Revit是一款专业的BIM(Building Information Modeling)软件,可以对建筑模型进行设计、分析和文档编制。在Revit,用户可以进行多种类型的数据交互,其就包括与SQL数据的交互。 如何进行Revit和SQL之间的数据交互呢? 1. 使用插件: 用户可以通过安装第三方插件在Revit进行SQL数据库的访问和交互。这些插件可以帮助用户快速读取和更新SQL数据库的数据。 2. 自定义代码:Revit还提供了API,使得用户可以自定义代码,通过编程实现与SQL数据库进行数据交互。API提供了一系列的类和方法,用户可以根据自己的需求进行调用和编写代码。 3. 数据映射:在Revit,用户可以将建筑对象与SQL数据库的数据进行映射,以实现数据的同步更新。这个功能可以很好的保持模型和数据库的数据的一致性,减少了手动操作的繁琐。 无论是使用插件,还是自定义代码,都需要用户熟悉SQL数据库Revit软件的操作,才能更好的进行数据交互。同时,数据交互的安全性和完整性也需要用户注意和保护。相信随着BIM技术的发展,Revit和SQL之间的数据交互也会越来越普及和深入。 ### 回答2: Revit是建筑、结构和MEP(机电管道)方面的一种软件。SQL(结构化查询语言)是一种用于管理和处理关系型数据库的语言。Revit与SQL数据交互的基本思想是将Revit的数据与SQL服务器的数据相互传递,以实现大规模建筑项目的更高效和更精确的管理。 Revit数据到数据库的传递可以通过编程方式实现。对于这种应用程序编程接口(API)编程,开发工具的选择是关键。许多可用的开发工具可以将Revit的数据传输到SQL数据库,但不同的开发工具需要不同的开发技术和知识背景。 目前,Revit API是最常用和最流行的开发工具之一。Revit API允许开发人员创建自定义插件,这些插件可实现Revit与SQL之间的数据传递。此外,Revit API还提供了许多客户端库和API,可以自动化生成高品质的Revit模型。该API还支持来自多个数据源的信息如Excel、数据文本、Web服务等。 Revit可以使用多种方法将数据存储到SQL数据库。可以通过构建特定的SQL数据存储表将数据直接输入SQL服务器。此外,开发人员还可以使用数据访问层(DAL)的技术,这种技术将创建一组类来处理数据调用和数据库读取。最后,还可以使用ORM(对象关系映射)技术将数据直接存储到对象,这种技术允许程序员使用对象模型来管理数据。 总之,Revit与SQL数据库之间的数据交互可以帮助建筑项目的管理和监控。通过编程技术和工具,可以更好地实现这种数据交互,从而带来更高效、更准确的建筑项目管理。 ### 回答3: Revit是建筑信息模型(BIM)软件,它可以通过SQL(结构化查询语言)与数据库交互。这种数据交互方式有助于在Revit管理大型建筑项目数据,如构件属性、面积计算、材料、成本等信息,同时也可以将这些数据用于设计和分析。 使用SQL将数据引入Revit有很多好处,其最重要的是保证了数据的准确性。通过使用SQL语言,可以避免输入错误和误解数据的情况发生,也可以更加有效地管理数据。 在Revit,通过使用IFC(工业基础设施分类)和RVT(Revit Project)文件的XML文件,可以扩展Revit模型,将其与其他建筑BIM软件集成。同时,在文件可以嵌入SQL查询,从而为整个项目提供更加高效的数据管理和分析功能。 在建筑行业,SQL是一种非常重要的工具,因为它使得建筑师、设计师和工程师们可以轻松地管理、组织和共享数据。如果想要在Revit实现更高效的数据交互,那么应该学会如何使用SQL语言,以便更好地处理和管理数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值