forked from jchristel/SampleCodeRevitBatchProcessor
-
Notifications
You must be signed in to change notification settings - Fork 0
/
ModifyModelMilestone.py
147 lines (124 loc) · 4.42 KB
/
ModifyModelMilestone.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
#!/usr/bin/python
# -*- coding: utf-8 -*-
#
#License:
#
#
# Revit Batch Processor Sample Code
#
# Copyright (c) 2020 Jan Christel
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
#
# this sample creates a dated back-up folder in a given location and than re-creates a central file with the same name in the new location
# batch processor settings should be:
# - detach model
# - all worksets closed
# - audit on opening
# - preserve worskets
# the SaveAs() method will compress the newly created central file by default
import clr
import System
import os
from os import path
# flag whether this runs in debug or not
debug_ = False
# --------------------------
# default file path locations
# --------------------------
# store output (models) here:
rootPath_ = r'C:\temp'
# path to Common.py
commonlibraryDebugLocation_ = r'C:\temp'
# debug mode revit project file name
debugRevitFileName_ = r'C:\temp\Test_Files.rvt'
# Add batch processor scripting references
if not debug_:
import revit_script_util
import revit_file_util
clr.AddReference('RevitAPI')
clr.AddReference('RevitAPIUI')
# NOTE: these only make sense for batch Revit file processing mode.
doc = revit_script_util.GetScriptDocument()
revitFilePath_ = revit_script_util.GetRevitFilePath()
else:
# get default revit file name
revitFilePath_ = debugRevitFileName_
# set path to common library
import sys
sys.path.append(commonlibraryDebugLocation_)
# import common library
import Common as com
from Common import *
# import Result as res #not required in this module
# folder methods are in here:
import Common_Post as cp
from Common_Post import *
clr.AddReference('System.Core')
clr.ImportExtensions(System.Linq)
from Autodesk.Revit.DB import *
# output messages either to batch processor (debug = False) or console (debug = True)
def Output(message = ''):
if not debug_:
revit_script_util.Output(str(message))
else:
print (message)
# -------------
# my code here:
# -------------
def CreateFolder(root, folderName):
dirName = path.join(root,folderName)
flag = True
try:
# Create target Directory
Output('Creating directory ' + dirName)
os.mkdir(dirName)
except Exception:
flag = False
return flag
def CreateTargetFolder(targetLocation, folderName):
returnFolderName = folderName
#check if folder exists
flag = False
if(path.exists(targetLocation + '\\' + folderName) == False):
flag = CreateFolder(targetLocation, folderName)
else:
#create new folder
flag = True
return flag, returnFolderName
# -------------
# main:
# -------------
# list containing the default file name:
# which in case of this back up is the same as the current file name
# [[revit host file name before save, revit host file name after save]]
defaultFileNames_ = [[com.GetRevitFileName(revitFilePath_), com.GetRevitFileName(revitFilePath_)]]
#save revit file to new location
Output('Modifying Revit File.... start')
# get mile stone folder
flagGotFolder_, milestonePath_ = CreateTargetFolder(rootPath_, cp.GetFolderDateStamp() + str('_Milestone'))
# do we have a valid folder?
if (flagGotFolder_):
# save new central file to back up folder
result_ = com.SaveAs(doc, rootPath_ + '\\' + milestonePath_, revitFilePath_ , defaultFileNames_)
Output(result_.message + ' :: ' + str(result_.status))
# sync changes back to central
if (debug_ == False):
Output('Syncing to Central: start')
syncing_ = com.SyncFile (doc)
Output('Syncing to Central: finished ' + str(syncing_.status))
else:
Output('failed to create target folder ' + rootPath_ + '\\' + cp.GetFolderDateStamp() + str('_Milestone'))
('Modifying Revit File.... finished ')