9.9.2010 1:14   /  Kontakt  /  O strani  /  Partnerji  /  Statistika  /  Slo  /  Ger  /  Hr  /  
 Domov Forum SolidWorks Pregled teme
 
 Uvoz točk iz excela v SW
 Objavi novo temo  /  Odgovori na temo Poglej prejšnjo temo :: Poglej naslednjo temo
Avtor Sporočilo
29010707
Strokovnjak
Strokovnjak


Pridružen-a: avg. 2005
Prispevkov: 101
PrispevekObjavljeno: 02.02.2010 8:49 
Naslov: Uvoz točk iz excela v SW

Pozdravljeni!
V SW znam uvoziti krivuljo iz Excelove datoteke oziroma txt datoteke. Ne znam pa narisano krivuljo v SW ali AutoCADu eksportirati v Excel oziroma txt datoteko. A mi zna kdo pomagati?
Lp!
    Odgovori s citatom
baklava
Strokovnjak
Strokovnjak


Pridružen-a: feb. 2005
Prispevkov: 232
PrispevekObjavljeno: 02.02.2010 9:02 
Naslov: Re: Uvoz točk iz excela v SW

29010707 je napisal/a:
Pozdravljeni!
V SW znam uvoziti krivuljo iz Excelove datoteke oziroma txt datoteke. Ne znam pa narisano krivuljo v SW ali AutoCADu eksportirati v Excel oziroma txt datoteko. A mi zna kdo pomagati?
Lp!


za autocad:

označi krivuljo-vpiši ukaz LIST-odpre se okno "text window"-skopiraš v *.txt file-odpreš v excelu

LP
    Odgovori s citatom
ManiaC
Strokovnjak
Strokovnjak


Pridružen-a: feb. 2005
Prispevkov: 364
PrispevekObjavljeno: 02.02.2010 17:43 
Naslov:

Sem ti spisal en kratek macro za SolidWorks, da ti naredi to.

Za uporabo pa naredi naslednje:
1.označen moraš imeti sketch, iz katerega hočeš povleči točke
2.pojdo pod tools-->macro->run, ter poišči datoteko Tocke.swp kamor si si le to datoteko shranil
3. točke najdeš v datoteki na c:\Tocke.txt

deluje za navaden sketch kot tudi za 3D sketch

http://www.megaupload.com/?d=U3ZAWL1R

p.s. zakaj ne morem na tem portalu pripeti .zip datoteko, ki jo zgenerira winrar, napiše mi da ta datoteki ni .zip, kljub temu da je.
    Odgovori s citatom
29010707
Strokovnjak
Strokovnjak


Pridružen-a: avg. 2005
Prispevkov: 101
PrispevekObjavljeno: 03.02.2010 8:12 
Naslov:

Hvala obema.
Majhen problem pri List v AutoCadu je, da moraš brisati nepotreben tekst in ker imam dosti točk mi to predstavlja kar delo.
Macro pa v mojem SW 2007 ne deluje, oziroma na c: ne najdem nobene txt datoteke s točkami, tako da ne vem kje je problem.
    Odgovori s citatom
baklava
Strokovnjak
Strokovnjak


Pridružen-a: feb. 2005
Prispevkov: 232
PrispevekObjavljeno: 03.02.2010 8:39 
Naslov:

29010707 je napisal/a:
Hvala obema.
Majhen problem pri List v AutoCadu je, da moraš brisati nepotreben tekst in ker imam dosti točk mi to predstavlja kar delo.
Macro pa v mojem SW 2007 ne deluje, oziroma na c: ne najdem nobene txt datoteke s točkami, tako da ne vem kje je problem.


odpri v Excelu in v njem urejaj pdoatke. Če pravilno odpreš *.txt file u Excelu boš dobil uporabne podatke, samo bodi previden na decimalno vejico i piko!

koliko imaš točke, približno?

LP
    Odgovori s citatom
ManiaC
Strokovnjak
Strokovnjak


Pridružen-a: feb. 2005
Prispevkov: 364
PrispevekObjavljeno: 03.02.2010 8:40 
Naslov:

Sam imam sicer sw 2009, vendar mislim da bi moralo delovati tudi na 2007, saj je macro spisan v vba in bi moral delovati na starejših sw.

Pripenjam sliko, po kateri meni deluje:



Lahko pa probaš sam spisati macro, ter ga nato z debuggerjem pognat. Pa mi povej, če ti slučajno najde kakšno napako.

To narediš tako, da daš tools->macro->new in vpišeš ime macroja.
Nato pa kopiraj spodnji tekst in pritisni tipko play(skica mora biti še vedno označena):

Sub ProcessSketchPoint(SwApp As SldWorks.SldWorks, swModel As SldWorks.ModelDoc2, swSkPt As SldWorks.SketchPoint)
Dim vID As Variant
Dim swSketch As SldWorks.Sketch
Dim nPt(2) As Double
Dim vPt As Variant

Set swSketch = swSkPt.GetSketch

'pridobi sketch informacije
vID = swSkPt.GetID

'shranimo posamezno točko v matriko nPt
nPt(0) = swSkPt.x: nPt(1) = swSkPt.Y: nPt(2) = swSkPt.Z

'zapiše točke v datoteke
'množimo jih s 1000 da dobimo mm, osnovne enote so metri
Write #1, "x=" & nPt(0) * 1000 & " " & "y=" & nPt(1) * 1000 & " " & "z=" & nPt(2) * 1000


End Sub

Sub main()
Dim SwApp As SldWorks.SldWorks
Dim swModel As SldWorks.ModelDoc2
Dim swSelMgr As SldWorks.SelectionMgr
Dim swFeat As SldWorks.Feature
Dim swSketch As SldWorks.Sketch
Dim vSkPtArr As Variant
Dim vSkPt As Variant
Dim swSkPt As SldWorks.SketchPoint

Set SwApp = Application.SldWorks
Set swModel = SwApp.ActiveDoc
Set swSelMgr = swModel.SelectionManager
Set swFeat = swSelMgr.GetSelectedObject6(1, 0)
Set swSketch = swFeat.GetSpecificFeature2

'preverjamo, če točke v sketchu sploh obstajajo
vSkPtArr = swSketch.GetSketchPoints2: If IsEmpty(vSkPtArr) Then Exit Sub

'pot do datoteke, kamor bodo shranjene točke
Open "c:\tocke.txt" For Output As #1

'For zanka, da dobimo vse točke v sketchu
For Each vSkPt In vSkPtArr

Set swSkPt = vSkPt
ProcessSketchPoint SwApp, swModel, swSkPt

Next vSkPt

'zapremo datoteko, ko končani operaciji
Close #1
End Sub
    Odgovori s citatom
29010707
Strokovnjak
Strokovnjak


Pridružen-a: avg. 2005
Prispevkov: 101
PrispevekObjavljeno: 03.02.2010 8:54 
Naslov:

Pri izdelavi macroja mi, ko pritisnem tipko play (run) javi naslednjo napako:

Compile error
Ambigiuous name detected: main

Kaj pa to pomeni pa ne vem.

Glede izvoza točk v excelu in nadaljni obdelavi v excelu pa imam problem, ker v excelu ne znam brisati praznih celic. Primer
A B
5 5
0 2
0 4
2
0
0
4
Kako lahko v excelu prenesem vrednosti brez praznih celic oziroma nul v naslednji stolpec in to tako, da vmes ni praznih celic oziroma vrstic.
Upam da je razumljivo napisano.
    Odgovori s citatom
ManiaC
Strokovnjak
Strokovnjak


Pridružen-a: feb. 2005
Prispevkov: 364
PrispevekObjavljeno: 03.02.2010 9:11 
Naslov:

probaj to kodo(odstranil sem številke pri modeldoc2 in podobnih, mogoče je to problem da ne deluje pri starejši verziji). Če pa še vedno to ne bo delovalo, pa bom probal pogledat jutri zvečer ko pridem domov na računalniku, kjer imam sw 2007.

Sub ProcessSketchPoint(SwApp As SldWorks.SldWorks, swModel As SldWorks.ModelDoc, swSkPt As SldWorks.SketchPoint)
Dim vID As Variant
Dim swSketch As SldWorks.Sketch
Dim nPt(2) As Double
Dim vPt As Variant

Set swSketch = swSkPt.GetSketch

'pridobi sketch informacije
vID = swSkPt.GetID

'shranimo posamezno točko v matriko nPt
nPt(0) = swSkPt.x: nPt(1) = swSkPt.Y: nPt(2) = swSkPt.Z

'zapiše točke v datoteke
'množimo jih s 1000 da dobimo mm, osnovne enote so metri
Write #1, "x=" & nPt(0) * 1000 & " " & "y=" & nPt(1) * 1000 & " " & "z=" & nPt(2) * 1000


End Sub

Sub main()
Dim SwApp As SldWorks.SldWorks
Dim swModel As SldWorks.ModelDoc
Dim swSelMgr As SldWorks.SelectionMgr
Dim swFeat As SldWorks.Feature
Dim swSketch As SldWorks.Sketch
Dim vSkPtArr As Variant
Dim vSkPt As Variant
Dim swSkPt As SldWorks.SketchPoint

Set SwApp = Application.SldWorks
Set swModel = SwApp.ActiveDoc
Set swSelMgr = swModel.SelectionManager
Set swFeat = swSelMgr.GetSelectedObject(1)
Set swSketch = swFeat.GetSpecificFeature

'preverjamo, če točke v sketchu sploh obstajajo
vSkPtArr = swSketch.GetSketchPoints: If IsEmpty(vSkPtArr) Then Exit Sub

'pot do datoteke, kamor bodo shranjene točke
Open "c:\tocke.txt" For Output As #1

'For zanka, da dobimo vse točke v sketchu
For Each vSkPt In vSkPtArr

Set swSkPt = vSkPt
ProcessSketchPoint SwApp, swModel, swSkPt

Next vSkPt

'zapremo datoteko, ko končani operaciji
Close #1
End Sub
    Odgovori s citatom
29010707
Strokovnjak
Strokovnjak


Pridružen-a: avg. 2005
Prispevkov: 101
PrispevekObjavljeno: 03.02.2010 9:40 
Naslov:

Sem ponovno probal, pa mi ne deluje. Ne vem....
    Odgovori s citatom
29010707
Strokovnjak
Strokovnjak


Pridružen-a: avg. 2005
Prispevkov: 101
PrispevekObjavljeno: 09.02.2010 16:54 
Naslov:

Deluje!
Hvala ManiaC!
    Odgovori s citatom
 Objavi novo temo  /  Odgovori na temo Poglej prejšnjo temo :: Poglej naslednjo temo
 Stran 1 od 1
 
     Oblika za tiskanje
 
Forum deluje na phpBB 
Objavljanje v forumu je omogočeno le v sistem prijavljenim obiskovalcem

Nova tema: Izberete temo in znotraj teme kliknite "Objavi novo temo".
Odgovarjanje: Izberete objavo, ki vas zanima in kliknite na povezavo "Odgovori".

 
ZLATI

Audax, d.o.o.
Sibo G., d.o.o.
Polycom, d.o.o.
National Instruments
Lj. univ. inkubator
CADCAM LAB, d.o.o.
Laboratorij LABOD, FS
Rodex, d.o.o.
Jež Janez s.p.
ib-CADdy d.o.o.
Difa d.o.o.
IRT3000
SolidCAM d.o.o.
3way s.p.
Castrol, BP, Aral
Danfoss Trata, d.o.o.
Gorenje Orodjarna, d.o.o.
ITS, d.o.o.
BRINOX d.o.o.
Moje Delo d.o.o.
Teximp d.o.o.
CAJHEN Rezilna orodja
SANDVIK, d.o.o.
Rappold Winterthur d.o.o.
SIMAL d.o.o.
PETRA Stroji d.o.o.
SICO d.o.o.
SECO TOOLS d.o.o.
Messer Slovenija
KOCH, d.o.o.
ACADEMIA d.o.o.
MB-NAKLO d.o.o.
ETRA d.o.o.
ICES
SAX konstrukcije d.o.o.
Intellectus - prevajanje
CODEX d.o.o.
Virs d.o.o.
2ER
Indeo d.o.o.
Društvo vzdrževalcev
b2b-navigator
DOMINO TRADE d.o.o.
LTH Ulitki d.o.o.
JAPTI - foruminovacij

SREBRNI

Iskra Mehanizmi, d.d.
BASIC d.o.o.
SCHMIDT HSC, d.o.o.
Klasand d.o.o.
Siliko d.o.o.
BENI TEHING d.o.o.
HENNLICH d.o.o.
IB-PROCADD d.o.o.
Fuchs maziva LSL d.o.o.
SASPRO d.o.o.
CAMINCAM d.o.o.
GAZELA d.o.o.
Fingal d.o.o.
FerroČrtalič d.o.o.
Cismatik Saša Ciglar s.p.
Misko d.o.o.
J.Čigon s.p.-rabljeni stroji
Olma d.d.
SENATOR d.o.o.
MiniTec d.o.o.
Danfoss d.o.o.
Inoks d.o.o.
Chemets, Kranj, d.o.o.
Agencija POTI, d.o.o.
Petrič d.o.o.
KNUTH GmbH
DIMAS d.o.o.
QS d.o.o.
ILANOTECH d.o.o.
Bojan Volaj s.p.
LOTRIČ d.o.o.
DIAMAT d.o.o.
TEHIMPEX d.o.o.
EXOR ETI d.o.o.
PLEVNIK d.o.o.
TECHNE d.o.o.
Oštir Sonja s.p.
MAPRO d.o.o.
SAPA Sandi Paljk s.p.
Eso Inženiring d.o.o.

BRONASTI

A-CAM, inženiring, d.o.o.
ORPO - elektroerozija
Hobotnica, d.o.o., Kranj
Socia, d.o.o.
SMD Gašper Oder, s.p.
CME Orodjarstvo, d.o.o.
Decca d.o.o.
Remic - lasersko varjenje
Libela orodja d.o.o.
Val plastika d.o.o.
Metalkom d.o.o.
SKITTI - Smrkolj Jože
Nova-zaposlitev.si
Akrapovič, d.d.
Zaposlitev.net
MP&D d.o.o.
INSATOOL d.o.o.
Vpenjalni sistemi d.o.o.
Flexmatic d.o.o.
Cating d.o.o.
Inoprojekt d.o.o.
Rimaz d.o.o.
Koplas d.o.o.
STROJNA GONILA d.o.o.
Swaty d.d.
ZUVAR
XREZ, Jeraj plus d.o.o.
Siga d.o.o., Žabnica
Weber d.o.o.
Uniplast d.o.o.
Frigor d.o.o.
RPS d.o.o. Ljubljana
TEHNA PLUS d.o.o.
Tipteh d.o.o.
KOVINC d.o.o.
PLASTIKA BEVC d.o.o.
HIB, Kranj, d.o.o.
GORENC -Igor Stare s.p.
Iskra OTC Kranj, d.o.o.
LGM d.o.o.
ARO.VANA d.o.o.
TOKAM d.o.o.
BIZJAN orodjarstvo d.o.o.
BOS Grubar d.o.o.
Žlindra d.o.o.
Tinmat d.o.o.
TECOS
SimTec
Birocom2000
STILLPLAS
SONET PLUS, d.o.o.
Orodjarstvo Pečnik Maks
6-Sigma Akademija
IZ HERA
M TRADE d.o.o.
Marija Debevec s.p.
Tuli d.o.o.
3D Biro
MARO d.o.o. - FILTRI
VAR-TEHNIKA d.o.o.
KVT-KOENIG
MK NOVAK
Litostroj Jeklo d.o.o.
STROJEGRADNJA ŠKORJANEC & CO.
JURIČ k.d.
pnevmatske-napeljave.si
Kontakt P d.o.o.
EKORA Jurij Ravnik s.p.
Magnetni ventili - Štern...
MIEL Elektronika d.o.o.
Čista energija d.o.o.
Libera d.o.o.
Kovačič d.o.o.
Galileo 3000 d.o.o.
Gruden Janko s.p.
Strojegradnja KOLETNIK

   © 2001 - 2009 STROJNISTVO.com  ::  e-pošta: info@strojnistvo.com  ::  Varstvo osebnih podatkov