PyRevit Uncle talks about Revit API, pyRevit and PreFlight Checks

Jean-Marc Couffin is the most active member of pyRevit Community. He is the one who orginizes a lot of things and keeps pyRevit engines turning. Check his masterclass on Pre-Flight check where he also shares a lot of tips and tricks about Revit API and pyRevit.

PyRevit Uncle talks about Revit API, pyRevit and PreFlight Checks

Jean-Marc Couffin is the most active member of pyRevit Community. He is the one who orginizes a lot of things and keeps pyRevit engines turning. Check his masterclass on Pre-Flight check where he also shares a lot of tips and tricks about Revit API and pyRevit.

Summary

Jean-Marc's Code:
# -*- coding: utf-8 -*-
from pyrevit import revit, DB, HOST_APP
from pyrevit import script
from pyrevit.preflight import PreflightTestCase


output = script.get_output()
output.close_others()
doc = HOST_APP.doc

# get the linked documents
link_instances = DB.FilteredElementCollector(doc).OfClass(DB.RevitLinkInstance).ToElements()
link_docs = []
if link_instances:
    for link_instance in link_instances:
        link_doc = link_instance.GetLinkDocument()
        link_docs.append(link_doc)


def ef_tools_check(document = doc, op = output):
    # get the document info
    document_info(document, op)
    # get the walls info
    walls_info(document, op)
    # get the grids info
    grids_info(document, op)


def document_info(document = doc, op = output):
    # get the project name
    project_title = document.Title
    project_name = document.ProjectInformation.Name
    # get the project number
    project_number = document.ProjectInformation.Number
    # get the project address
    project_address = document.ProjectInformation.Address

    op.print_md("## Project Info")
    op.print_md("### {}".format(project_name))
    op.print_md("Project Title: {}".format(project_title))
    op.print_md("Project Number: {}".format(project_number))
    op.print_md("Project Address: {}".format(project_address))


def walls_info(document = doc, op = output):
    walls = DB.FilteredElementCollector(document).OfCategory(DB.BuiltInCategory.OST_Walls)
    walls_instances = walls.WhereElementIsNotElementType()
    if walls_instances.GetElementCount() > 0:
        # get the wall count
        walls_count = walls_instances.GetElementCount()
        op.print_md("**Walls: **{}".format(walls_count))
        # get the wall name
        walls_names = [wall.Name for wall in walls_instances]
        # get the wall id
        walls_ids = []
        for wall in walls_instances.ToElements():
            walls_ids.append(op.linkify(wall.Id))
        # get wall length
        wall_length = []
        for wall in walls_instances.ToElements():
            try:
                wall_length.append(wall.get_Parameter(DB.BuiltInParameter.CURVE_ELEM_LENGTH).AsValueString()+"mm")
            except:
                wall_length.append("N/A")
        # get the wall workset
        walls_workset = elements_worksets(document, walls_instances)

        op.print_table(title="Walls", columns=["Wall name", "Wall id", "Wall Length", "Wall Workset"], table_data=zip(walls_names, walls_ids, wall_length, walls_workset))
    else:
        op.print_md("**No walls found**")


def grids_info(document = doc, op = output):
    grids = DB.FilteredElementCollector(document).OfCategory(DB.BuiltInCategory.OST_Grids)
    grid_instances = grids.WhereElementIsNotElementType()
    if grid_instances.GetElementCount() > 0:
        # get the grid count
        grids_count = grid_instances.GetElementCount()
        op.print_md("**Grids: **{}".format(grids_count))
        # get the grid name
        grid_names = [grid.Name for grid in grid_instances]
        # get the grid id
        grids_ids = []
        for grid in grid_instances.ToElements():
            grids_ids.append(op.linkify(grid.Id))
        # get the grid workset
        grids_workset = elements_worksets(document, grid_instances)
        op.print_table(title="Grids", columns=["Grid name", "Grid id", "Grid workset"], table_data=zip(grid_names, grids_ids, grids_workset))
    else:
        op.print_md("**No grids found**")


def elements_worksets(document = doc, element_instances = None):
    element_worksets = []
    for element in element_instances.ToElements():
        if document.IsWorkshared:
            element_worksets.append(element.get_Parameter(DB.BuiltInParameter.ELEM_PARTITION_PARAM).AsValueString())
        else:
            element_worksets.append("File is not workshared")
    return element_worksets


class ModelChecker(PreflightTestCase):
    """
    List all walls and their info and get some of the model info
    This QC tool returns you with the following data:
        - Model info: project name, project number, project address
        - Wall count, wall name, wall id, wall length, wall workset (if workshared)
        - Grid count, grid name, grid id, grid workset (if workshared)
    """
    
    name = "EF_tools_checker"
    author = "Jean-Marc Couffin"

    def setUp(self, doc, output):
        pass

    def startTest(self, doc, output):
        output.print_md("# EF_Tools check")
        ef_tools_check(doc, output)
        for link_doc in link_docs:
            if link_doc:
                ef_tools_check(link_doc)

    def tearDown(self, doc, output):
        pass

    def doCleanups(self, doc, output):
        pass

Discuss the lesson:

P.S. Sometimes this chat might experience connection issues.
Please be patient or join via Discord app so you can get the most out of this community and get access to even more chats.

P.S. Sometimes this chat might experience connection issues.
Please be patient or join via Discord app so you can get the most out of this community and get access to even more chats.

© 2023-2024 EF Learn Revit API

© 2023-2024 EF Learn Revit API

© 2023-2024 EF Learn Revit API