надеюсь, это поможет.
Сначала вам нужно открыть файл проекта:
ProjectReader reader = ProjectReaderUtility.getProjectReader(inputFile);
ProjectFile projectFile = reader.read(inputFile);
Это предполагает, что у вас есть имя файла в строке inputFile.
Приведенный ниже метод следует рассматривать как псевдокод (т.е. я его не компилировал, не вытряхивал из него баги и т. д., и это не самое элегантное, что я когда-либо писал), но он иллюстрирует подход:
public void dumpTables(ProjectFile file)
{
List tables = file.getTables();
Iterator iter = tables.iterator();
while (iter.hasNext())
{
Table table = (Table)iter.next();
if (table.getResourceFlag())
{
List resources = file.getAllResources();
Iterator resourceIter = resources.iterator();
while (resourceIter.hasNext())
{
Resource resource = (Resource)iter.next();
List columns = table.getColumns();
Iterator columnIter = columns.iterator();
while (columnIter.hasNext())
{
Column column = (Column)columnIter.next();
Object columnValue = resource.getCachedValue(column.getFieldType());
Console.Write(columnValue);
Console.Write(",");
}
Console.WriteLine();
}
}
else
{
List tasks = file.getAllTasks();
// etc. as above
}
}
}
Идея состоит в том, что вы получаете список таблиц, присутствующих в файле, и для каждой из них решаете, является ли она таблицей задач или ресурсов. На основе этого вы получите список задач или ресурсов, выполните итерацию по нему и для каждого экземпляра извлеките значение столбца и отобразите его. Обратите внимание, что я не пытался упорядочить задачи или ресурсы каким-либо определенным образом. Я оставлю это в качестве упражнения для читателя!
Надеюсь, это поможет!
Джон
person
Jon Iles
schedule
16.12.2010