TheXman Posted October 29, 2018 Posted October 29, 2018 1 hour ago, TheXman said: I'm not exactly sure how AutoIt works in this regard without testing it, but in other languages, objects are passed ByRef. Therefore, if the same holds true you aren't using a copy of the $jsonfunc object in myfunc(), you are using/manipulating the object itself. For the record, when I used the term "ByRef" above, I was not referring to the keyword ByRef. It was just my shorthand way of saying "by reference", in other words using a pointer. CryptoNG UDF: Cryptography API: Next Gen jq UDF: Powerful and Flexible JSON Processor | jqPlayground: An Interactive JSON Processor Xml2Json UDF: Transform XML to JSON | HttpApi UDF: HTTP Server API | Roku Remote: Example Script About Me How To Ask Good Questions On Technical And Scientific Forums (Detailed) | How to Ask Good Technical Questions (Brief) "Any fool can know. The point is to understand." -Albert Einstein "If you think you're a big fish, it's probably because you only swim in small ponds." ~TheXman
Developers Jos Posted October 29, 2018 Developers Posted October 29, 2018 (edited) 4 minutes ago, TheXman said: For the record, when I used the term "ByRef" above, I was not referring to the keyword ByRef. It was just my shorthand way of saying "by reference", in other words using a pointer. Understand, but just wanted to avoid confusion. All that Byref would do is created a PTR ($jsonparam) to a PTR ($jsonfunc) which obviously still point to the same memory space, hence my comment it being a mute point. Jos Edited October 29, 2018 by Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
satanico64 Posted October 29, 2018 Posted October 29, 2018 (edited) First of all, sorry for being tenacious, i am really impressed by the whole work that the autoit team does here, so i really take my time before responding and i'm gratefull for you to take time. But in fact, i still disagree (sorry for that) The problem here, is that is seems that the parameter passed, is a pointer to the json passed when we call the function. I agree with that... but why ? It is not the case when called with a string variable ... You must agree that, for a same function, we do not have the same result, depending of the type of parameter passed. (string or json.. for example). I do not understand why it would be normal. $json param point to the same memory allocation that $jsonfunc, why ? A function parameter MUST be in local scope, so it should allocate memory et duplicate data not point to the variable (something like that). Am i wrong ? Nicolas [Edit: adding signature and my prettiest smileys ] Edited October 29, 2018 by satanico64
Developers Jos Posted October 29, 2018 Developers Posted October 29, 2018 6 minutes ago, satanico64 said: But in fact, i still disagree (sorry for that) ... and that is fine, but it is what it is. Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
satanico64 Posted October 29, 2018 Posted October 29, 2018 A function parameter MUST be in local scope, so it should allocate memory et duplicate data not point to the variable (something like that). Am i wrong ? Nicolas.
maniootek Posted December 16, 2018 Posted December 16, 2018 I just downloaded Quote _Json(2018.10.28).zip and file Json.au3 first line says: Quote ; File : Json.au3 (2015.01.08) are you sure you uploaded right version? you also said you fixed Au3Check warnings On 7.02.2013 at 12:11 PM, Ward said: == Update 2018/10/01b== (Jos) * Added Json_ObjGetItems, Tidied source and fixed au3check warnings - tnx @TheXman . == Update 2018/10/28== (Jos) * Added declaration for $value to avoid au3check warning - tnx @DerPensionist but I still see one:
Developers Jos Posted December 16, 2018 Developers Posted December 16, 2018 Thanks for the report ... I've update the file and made a new update available in the first post. Jos Skysnake 1 SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
Acanis Posted December 27, 2018 Posted December 27, 2018 (edited) Hey, uh... Its fast, very nice and thank you :)! Can I use Json_ObjGet through several "levels"? I have a JSON with Object>Object>Object>Object>Object>Object>Array and I want to get the Array behind all the know objects. Do I need 6x Json_ObjGet or how do I adress that more simple? Thanks *edit* Json_Dump is showing me "." as seperator between the objects, but with Local $oTest = Json_ObjGet($oTemp, 'd.1') $aTest = Json_ObjGetItems($oTest) Local $oTest = Json_ObjGet($oTemp, 'd.1') $aTest = Json_ObjGetItems($oTest) _ArrayDisplay($aTest) I get "==> Variable must be of type "Object".:" If i just use 'd', its working, so the seperator isnt right, or maybe its not possitble? Edited December 27, 2018 by Acanis
Developers Jos Posted December 27, 2018 Developers Posted December 27, 2018 19 minutes ago, Acanis said: Ah, Json_Dump helped me understanding the formatting, still not sure, how I do check, if there is a special string in an array behind 6 objects. Post an example JSON data, the script you have that isn't working yet and an exact explanation of what you want so we can have a look. Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
Acanis Posted December 27, 2018 Posted December 27, 2018 13 minutes ago, Jos said: Post an example JSON data, the script you have that isn't working yet and an exact explanation of what you want so we can have a look. Jos Hey, Iam looking for a short way to do something like this: $sJson = ClipGet() $oTemp = Json_Decode($sJson) If Json_IsObject($oTemp) Then $oTemp1 = Json_ObjGet($oTemp, "d") $oTemp2 = Json_ObjGet($oTemp1, "5") $oTemp3 = Json_ObjGet($oTemp2, "4") $oTemp4 = Json_ObjGet($oTemp3, "6") MsgBox(4096, "", Json_ObjExists($oTemp4, "h") & @CRLF) EndIf ("h" is an array, which holds some informations) Can "Json_ObjGet" do this in 1 line? Like $oObject = Json_ObjGet($oTemp, "d.5.4.6") Thanks
Developers Jos Posted December 27, 2018 Developers Posted December 27, 2018 (edited) I am missing some test data to play with. Simply change the first line and put the actual JSON data there. Edited December 27, 2018 by Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
Acanis Posted December 27, 2018 Posted December 27, 2018 (edited) 48 minutes ago, Jos said: I am missing some test data to play with. Simply change the first line and put the actual JSON data there. Sorry, I thoughts that if its possible, it would be easier to see the code. I created a short example: expandcollapse popup#include <Json.au3> #include <Array.au3> $sJson = '{'& _ '"d": {' & _ '"5": {' & _ '"4": {' & _ '"6": {' & _ '"h": [' & _ '{' & _ '"id": "1286",' & _ '"status": "sunny",' & _ '"earth": true' & _ '}' & _ ']' & _ '}' & _ '}' & _ '}' & _ '}' & _ '}' $oTemp = Json_Decode($sJson) If Json_IsObject($oTemp) Then $oTemp1 = Json_ObjGet($oTemp, "d") $oTemp2 = Json_ObjGet($oTemp1, "5") $oTemp3 = Json_ObjGet($oTemp2, "4") $oTemp4 = Json_ObjGet($oTemp3, "6") If Json_ObjExists($oTemp4, "h") Then Local $aH = Json_ObjGet($oTemp4, "h") For $i = 0 To Ubound($aH) - 1 $iID = Json_ObjGet($aH[$i], "id") ConsoleWrite($iID & @CRLF) Next EndIf EndIf I want to check, if there is a "h"-object in d > 5 > 4 > 6 and if yes, get for example all the ids. Iam curious, if I need all the "temp"-objects. Maybe there is a notation for Json_ObjGet, that is doing this in less lines. Thank you Edited December 27, 2018 by Acanis
Developers Jos Posted December 27, 2018 Developers Posted December 27, 2018 mmm... don't think that is possible yet. Maybe we should add a recursive check to Json_ObjGet() and Json_ObjExists() like this: expandcollapse popup#include <Json.au3> $sJson = '{"d": {"5": {"4": {"6": {"h": [{"id": "1286","status": "sunny","earth": true}]}}}}}' Json_dump($sJson) $oTemp = Json_Decode($sJson) If Json_IsObject($oTemp) Then ConsoleWrite('@@ Json_ObjExists($oTemp, "d") = ' & Json_ObjExistsR($oTemp, "d") & @CRLF) ;### Debug Console ConsoleWrite('@@ Json_ObjExists($oTemp, "d.5") = ' & Json_ObjExistsR($oTemp, "d.5") & @CRLF) ;### Debug Console ConsoleWrite('@@ Json_ObjExists($oTemp, "d.5.4") = ' & Json_ObjExistsR($oTemp, "d.5.4") & @CRLF) ;### Debug Console ConsoleWrite('@@ Json_ObjExists($oTemp, "d.5.4.6") = ' & Json_ObjExistsR($oTemp, "d.5.4.6") & @CRLF) ;### Debug Console ConsoleWrite('@@ Json_ObjExists($oTemp, "d.5.4.6.h") = ' & Json_ObjExistsR($oTemp, "d.5.4.6.h") & @CRLF) ;### Debug Console ConsoleWrite('@@ Json_ObjExists($oTemp, "d.5.4.6.x") = ' & Json_ObjExistsR($oTemp, "d.5.4.6.x") & @CRLF) ;### Debug Console $oTempb = Json_ObjGetR($oTemp, "d.5.4.6.h") ConsoleWrite('@@ json_get($oTempb,''[0].id'') = ' & json_get($oTempb, '[0].id') & ' >Error code: ' & @error & @CRLF) ;### Debug Console $oTempb = Json_ObjGetR($oTemp, "d.5.4.6.x") ConsoleWrite('@@ json_get($oTempb,''[0].id'') = ' & json_get($oTempb, '[0].id') & ' >Error code: ' & @error & @CRLF) ;### Debug Console EndIf Func Json_ObjExistsR(ByRef $Object, $Key) Local $DynObject = $Object Local $Keys = StringSplit($Key, ".") For $x = 1 To $Keys[0] If $DynObject.Exists($Keys[$x]) Then If $x = $Keys[0] Then Return True Else $DynObject = Json_ObjGet($DynObject, $Keys[$x]) EndIf Else Return False EndIf Next Return $Object.Exists(String($Key)) EndFunc ;==>Json_ObjExistsR Func Json_ObjGetR(ByRef $Object, $Key) Local $DynObject = $Object Local $Keys = StringSplit($Key, ".") For $x = 1 To $Keys[0] If $DynObject.Exists($Keys[$x]) Then If $x = $Keys[0] Then Return $DynObject.Item($Keys[$x]) Else $DynObject = Json_ObjGet($DynObject, $Keys[$x]) EndIf EndIf Next Return SetError(1, 0, '') EndFunc ;==>Json_ObjGetR Thoughts? Jos argumentum and Acanis 1 1 SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
Acanis Posted December 27, 2018 Posted December 27, 2018 Hey, that looks really useful Thanks! Will you add it to the UDF?
Developers Jos Posted December 27, 2018 Developers Posted December 27, 2018 I will when nobody can think of any issues changing the code. Jos SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
Developers Jos Posted December 29, 2018 Developers Posted December 29, 2018 Updated the first page with the changed UDFs in the JSON.au3 include. Jos Skysnake and Acanis 2 SciTE4AutoIt3 Full installer Download page - Beta files Read before posting How to post scriptsource Forum etiquette Forum Rules Live for the present, Dream of the future, Learn from the past.
Acanis Posted January 1, 2019 Posted January 1, 2019 (edited) Happy New Year :)! I have very often problems like that: Quote "C:\PROGRA~2\AutoIt3\Include\Json.au3" (351) : ==> Variable must be of type "Object".: Return $Object.Keys() Return $Object^ ERROR Is there a way to easy find the calling point in my script? I use a lot of "Json_ObjGetKeys()" and I would like to find the reason, why I sometimes dont get an object at this part. How do you debug this in a good way :)? I could secure it with lots of "Json_ObjExists()", but maybe I should have an object there and my code isnt stable enough. Edited January 1, 2019 by Acanis Skysnake 1
TheDcoder Posted January 1, 2019 Posted January 1, 2019 @Acanis Generally you would want to implement error checking in your code as much as possible, so that your script does't stop because of an error like that. There is no easy way (as far as I am aware) to capture these error without getting AutoIt interrupted... 2 hours ago, Acanis said: but maybe I should have an object there and my code isnt stable enough. Yes, you are right about this. Acanis 1 EasyCodeIt - A cross-platform AutoIt implementation - Fund the development! (GitHub will double your donations for a limited time) DcodingTheWeb Forum - Follow for updates and Join for discussion
Acanis Posted January 1, 2019 Posted January 1, 2019 Should we add a little bit error handling to the UDF?! Quote "C:\PROGRA~2\AutoIt3\Include\Json.au3" (343) : ==> Variable must be of type "Object".: Return $Object.Exists(String($Key)) Return $Object^ ERROR Every of this could have a for example a "IsObject Else SetError Return".
argumentum Posted January 1, 2019 Posted January 1, 2019 3 minutes ago, Acanis said: Should we add a little bit error handling to the UDF?! Nope. Lets say the UDF checks for IsObj() and return an @error. Will you check for "If @Error Then" ? Just make sure you pass an object. Follow the link to my code contribution ( and other things too ). FAQ - Please Read Before Posting.
Recommended Posts
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 accountSign in
Already have an account? Sign in here.
Sign In Now