Мне удалось сделать хороший скрипт, который может генерировать файл MS-проекта из выбранных таблиц в Excel.Сейчас я ищу помощь, чтобы сделать ее немного более полезной.Я хотел бы вставить вехи в каждой основной задаче из конкретной таблицы в Excel.Каждое основное задание имеет соответствующую таблицу этапов.
Sub MSPexport()
Dim pjapp As Object
Dim strValue, strWorktime, strMilestone As String
Dim newproj
Set pjapp = CreateObject("MSProject.application")
If pjapp Is Nothing Then
MsgBox "Project is not installed"
End
End If
pjapp.Visible = True
Set newproj = pjapp.Projects.Add
Set ActiveProject = newproj
pjapp.NewTasksStartOn
'insert tasks here
For I = 3 To 8 'currently I am pointing to the range A3:A:8 - would like to make it a named range instead - ie "Maintasks" - how to do this?
strValue = Worksheets("Planning").Range("A" & I)
newproj.Tasks.Add (strValue)
'Insert predecessor if not first task
If I <> 3 Then
newproj.Tasks(I - 2).Predecessors = (I - 3)
End If
'here I would like to insert milestones as subtasks
For M = 3 to 5 ' this I also would like to be a named range and also I need to check for or lookup the correct main task and the corresponding milestone list
strMilestone = Worksheets("Milestones").Range("C" & M)
newproj.Tasks.Add (strMilestone)
newproj.Tasks(M - 2).Duration = 0
newproj.Tasks(M - 2).OutlineIndent
newproj.Tasks(M - 2).Predecessors = (I - 26)
Next M
Next I
End Sub
MS-Project должен выглядеть следующим образом: data:image/s3,"s3://crabby-images/16fb8/16fb8a63dc4f2baa54cd3ad1ed2a5173f1bca455" alt="The MS-Project should look like this when done"
data:image/s3,"s3://crabby-images/e44d7/e44d7729d8eedbbbff25907cd9fca6213a36eeed" alt="Excel tables"