Import/Export IFC - compiling IfcOpenShell/pl

Wprowadzenie
To było tak trudne dochodzenie, jak uzyskać działającą kopię IfcOpenShell-python na OSX/macOS w celu importowania/eksportowania plików IFC, że dzielę się tym poradnikiem na wypadek, gdyby pomógł większej liczbie osób. Mój system to OSX 10.11.6, 64bity z środowiskiem Python 2.7.11, może to zadziałać, jeśli masz również OSX, ponieważ często są one 64-bitowe, ale mogą się różnić od mojego. Procedura może być bardzo podobna, jeśli używasz Linuksa lub Windowsa, ale prawdopodobnie ma pewne różnice.

Wymagania

 * IfcOpenShell
 * FreeCAD w wersji 0.19 lub nowszej

Kroki
1. Pobierz lub sklonuj pełny projekt GitHub pod adresem https://github.com/IfcOpenShell/IfcOpenShell (zawsze będzie to najnowsza wersja)

2. Z terminala przejdź do folderu i uruchom skrypt. W systemie OSX jest on wykonywany za pomocą:

Kompilacja zajmie od 30 do 120 minut. Nie jest to najmądrzejszy sposób kompilacji IfcOpenShell, ale ten prosty skrypt skompiluje wszystkie zależności, wersje Python itp.

3. Po zakończeniu (nie pamiętam teraz, ale zostanie wypisane coś w stylu "Built IfcOpenShell..." i powróci do monitu) będziesz miał nowy folder pełen plików i folderów. Z mojego osobistego doświadczenia wynika, że dwa tygodnie temu skrypt nix "build-all.sh" nie zakończył się pomyślnie, ale po wypróbowaniu go wczoraj z najnowszymi aktualizacjami działał dobrze, więc przypuszczam, że możesz doświadczyć czegoś podobnego w przypadku dalszego rozwoju... Więc teraz masz wszystko, czego potrzebujesz, ale musisz wykonać trochę samodzielnej pracy, aby to zadziałało:

4. Otwórz FreeCAD i otwórz okna konsola Python i Widok raportu. Następnie wpisz w konsoli Python następujące polecenie:

Otrzymasz długą linię ze wszystkimi ścieżkami, które odczytuje FreeCAD. Możesz być w stanie zainstalować IfcOpenShell w dowolnej z nich, ale sugeruję umieszczenie go w takiej, w której znajdziesz po  lub. W moim przypadku był to. (Uwaga: znajdziesz ścieżki wewnątrz katalogu aplikacji, ale sugeruję ich nie używać, ponieważ wtedy IfcOpenShell będzie dostępny tylko dla tej aplikacji).

5. Po zlokalizowaniu miejsca, w którym chcesz / musisz go zainstalować, przejdź tam za pomocą przeglądarki plików (Finder w OSX). To znaczy, przejdź do folderu

6. Open a new file browser window and navigate to your downloaded GitHub project: /IfcOpenShell/src/ifcopenshell-python/ and copy the full /ifcopenshell/ folder

7. Paste it inside /site-packages/ folder. Now you should have something like:

8. Now we have to pick to files inside the /build/ folder, they are:

but as we have compiled everything you will have to pick the one that matches with your FreeCAD Python version. Check it easily reading the first line inside your FreeCAD Python console view. In my case it was Python 2.7.11.

9. Now go let's copy the files inside the place it corresponds to your Python version. In my case it was:

10. Paste them inside

11. Check everything is in place:

(1) from GitHub project

(2) from /build/ folder

12. Close and reopen FreeCAD

Testing
Now that it is installed, let's check if everything works as expected:

12.1 in the Python console write:

if it doesn't throw any error it means it may be correctly installed

12.2 Go to Yorik's FreeCAD manual, navigate to the lower part of the page and download the following files to test:

12.3 Open, select the root "Building" object and export it setting the File type to "Industry Foundation Classes (*.ifc)". Press and if it works and it doesn't throw an error in the Report view then it's working.

12.4 Final test, import into a new file so open a new file and import that file... it will take a while.

13. Ciesz się BIM dzięki FreeCAD!

Przemyślenia końcowe
Moim zdaniem sam FreeCAD powinien mieć prekompilowane wersje IfcOpenShell dołączone do dystrybucji, ponieważ samodzielne budowanie go jest totalnym bólem i przeciętny użytkownik tego nie zrobi (nie wie, jak kompilować, zarządzać GitHubem itp.), ale cóż, może w przyszłości.

Mam nadzieję, że to ci pomoże.

Dzięki.

Odnośniki internetowe

 * Powiązany wątek na forum dyskusyjnym
 * IfcOpenShell