Jump to content
Developer Wiki and Function Reference Links Read more... ×
David O

Converting Strings to Numbers

Recommended Posts

Hello Marionette lovers !

 

Is there anyway using existing nodes to convert strings (like the ones coming from the GetIFC Pset Value ... and many others from IPFC parameters...) into a number or Integer ?

Maybe the node Function could do this trick  ? (but was not capable to implement this properly ...) ?

 

Thanks for your valued inputs !

Share this post


Link to post

If the string is composed of entirely numbers, you can run it through the "float" node. It's a little trickier if you have units in the string, though, and those would require special handling.

Share this post


Link to post

Ok... got it. Tks Marissa !

Yes... i think that in case we do have units involved we better trying creating a custom node and do things in Python instead ... right ?

 

 

Share this post


Link to post

I would take the Function Node and use the formula x[:-2] (to remove the last to items of the string, or x[:-1] to remove the last one etc.). There will be other possibilities with other nodes but I first had to search the right ones.

 

 

Share this post


Link to post

Hello DomC

 

How does it work ?

Can I use it in the Datenmanager ?

I would like to display 0.30 instead of 0.30000000

 

Thank you for your Help

Bildschirmfoto 2019-03-06 um 08.44.21.png

Bildschirmfoto 2019-03-06 um 09.22.23.png

Share this post


Link to post

I try in Node

 

    area = vs.Round(vs.GetObjectVariableReal(obj,608)/0.01) * 0.01

 

by doing *0.01 the zeros come again.... 
 

Share this post


Link to post

Hi

Generally this are common issues:

1. If you have a String of 0.30000 and want to have have a string output from 0.30 you can youse x[:4]. The first 4 character of the string. If you have 100.45987 you will get 100. with this formula. If you use x[:-2] the last two characters are lost. To Prevent this, you could first split the string in number and digit and then operate with this.

2. Sometimes there are Units like m2 mm m qm etc.

3. Sometimes we want to have prefix like +. - and +- etc.

4. Sometimes there are , instead . of decimal seperators.

 

The attached Nodes, addresses all of this common issues. Simple issues, but relatively complexe to solve. I attached some node to solve them.

 

The error message you got is because to substract two items from a list (a string is like a list  '0', '.', '0', '0' etc. or a list of numbers will be [0,5,3,4.5,]). So with a Number of 0.30000 it will not work, this is just one item. You could convert to string str(x)[:-2]. Then it would work. Do not know what mapping is doing. If it converts the string of 0.3 in a number it Maybe by standard makes again 0.300000 in the IFC Export.

 

You see, not so trivial. I Recommend using the Attached Node Digits from string and try with this. 

 

Set Digits From String.vwx

  • Like 1

Share this post


Link to post

Thank you very much for your help...

 

I have another question:

How can I use the Node "Objs by Crit" for a Column ?

PON='Column' or T=Column  PON='Säule'

doesn't work...

 

The same question for a Door / Window / Fassade !?

 

Thank you so much for your Help...

Share this post


Link to post

@Thomas Gillioz

In 2019, the Objects by Criteria node has a button below it allowing you to define the Criteria using a dialog.

When I placed a column in my document and used that button, I was given

((PON='Column2'))

as my criteria.

If you are not seeing the button in the Object Info Palette with the Objs by Crit node selected, please replace the existing node with a new one from default content.

 

Screen Shot 2019-03-11 at 10.12.02 AM.png

Share this post


Link to post

it's me again,

 

😃

 

How can I create a node with 

 

object.OA Height

Shaft Depth

Shaft Width

 

??

 

Thanks a lot

Share this post


Link to post

Here's a short network that returns these values.

Often, values for Parametric Objects are stored in hidden records - this demonstrates how to extract the ones you've asked for.

Record fields are returned as strings (text), so they will need to be converted to numbers if you plan to use them elsewhere.

 

If you want to assign values to the object, you would instead use the Set Record Field node.

 

 

Marionette_ReturnColumnInfo_MFarrell.vwx

Share this post


Link to post

Thank you for your quick reply

and how do you convert String to Numbers ? so could I use the div node...

I need the 0.25 instead of 2.5e-01m or 2.5 

 

1986019731_Bildschirmfoto2019-03-11um18_43_29.thumb.png.af74fa9487c02ce2d5956edae33029ff.png

Share this post


Link to post

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

 

7150 Riverwood Drive, Columbia, Maryland 21046, USA   |   Contact Us:   410-290-5114

 

© 2018 Vectorworks, Inc. All Rights Reserved. Vectorworks, Inc. is part of the Nemetschek Group.

×