Closed GoogleCodeExporter closed 9 years ago
For some reason the link to the fiddle didn't show up.
One question, what browser are you using when it fails.
Either way, I think this may follow the same lines as bug 14. A new entry
parser is in the works so it may take a little time before I can get it fully
completed and tested. I'll post an update once the new code is available.
Original comment by evanpla...@gmail.com
on 24 Oct 2012 at 8:48
OK, so but 14 is fixed and a completely new parser has been rolled out.
Unfortunately, it still doesn't properly parse your dataset.
It's the null values that aren't being handled properly.
This subset of data will work:
"TimeStamp (ms)","MID 128|PID 91|Accelerator pedal position (%)","MID 128|PID
92|Engine load(%)","MID 128|PID 100|Engine oil pressure (bar)","MID 128|PID
105|Intake manifold temperature (N0C)","MID 128|PID 110|Engine coolant
temperature (N0C)","MID 128|PID 190|Engine speed (r/min)"
115,10.4,0,0,0,0,0
With my spiffy new parser, it shouldn't be too hard to fix.
Original comment by evanpla...@gmail.com
on 25 Oct 2012 at 3:34
Got it...
I have to commend you for providing a dataset that covers nearly every type of
null value use case scenario.
According to the specification, trailing commas aren't legal but that's a dumb
rule considering that unquoted null values are legal. My guess would be that
the people who wrote the RFC didn't take the time to consider how null values
would be used under realistic circumstances. Especially, since Excel (and most
other spreadsheet apps that can output CSV) don't quote all values by default.
Anyway, enough blabbering...
Feel free to try it out in the 'Basic Usage Demo':
http://jquery-csv.googlecode.com/git/examples/basic-usage.html
The code won't be officially available until 0.65 drops; if you want it now,
feel free to grab the source directly from the repository browser.
http://code.google.com/p/jquery-csv/source/browse/#git%2Fsrc
One last thing, the lineSplitter method that properly handles new-lines in
values is now the default; so you won't need to set experimental:true anymore.
Original comment by evanpla...@gmail.com
on 25 Oct 2012 at 4:26
Original comment by evanpla...@gmail.com
on 27 Oct 2012 at 5:40
Hi again. I might have another case scenario for you. lol
Replied the other day by email but i think it didn't get to you.
I have attached a 'raw file' that i am trying to parse (it was the original i
pasted the data out of) which does not seem to work. It drops off the last
value from each row if empty.
This is the sort of file I am trying to turn into a gviz on a regular basis.
Original comment by tribbleh...@gmail.com
on 27 Oct 2012 at 4:41
Attachments:
Let me finish rolling the custom delimiter/separator code in the new parser.
Technically, with the new parser it shouldn't encounter any issues with null
last values. I actually test for that specific use case now.
You can see it under tests, RFC Compliance, Amendment 3:
http://jquery-csv.googlecode.com/git/test/test.html
Original comment by evanpla...@gmail.com
on 28 Oct 2012 at 1:10
That's strange, I can reproduce the issue even though the parser should cover
that issue already.
I'll keep at it until I can get it to work.
Original comment by evanpla...@gmail.com
on 1 Nov 2012 at 10:41
OK, so after a whole lot of head scratching I think I finally found it.
It's actually comprised of 4 independent bugs.
The first two were related to null-last-values. The tests were passing because
the null last value fix isn't quite right. I was running the null-last-value
test using toArrays instead of toArray; the combination of two bugs combined
was causing the test to pass even though it wasn't coded correctly.
If I had tried it on multi-line data, the issue would have shown itself by
having every entry with a trailing null be short one value and the last one
having an extra null value added on.
My test samples are pretty extensive but apparently not enough.
The third bug, and the reason why the data was only being parsed to two cells
wide was being caused by the castToScalar function. For parser hooks, if you
return false it will skip that cell; this is useful for evaluation behavior
like extracting specific rows/cells. I forgot that Javascript mimics C
including some of the dumber practices like the fact that false == 0 and true
== 1. Not to difficult to fix once I realized the problem.
The last bug had to do with the way I was evaluating null values in
castToScalar. Technically, null can equal either '', 0, or false. For some
reason, isNaN interprets them as being a number. To fix it, I had to check the
return value from parseInt() for (ironically) NaN values.
It turns out I was right when I said that your dataset would break the null
parsing in every conceivable way possible.
Anyway, I'm still working out fixes for the first two bugs. While the FSM is a
lot easier to fine tune, it's very difficult to maintain a good mental model.
As soon as I have everything working I'll post a message here.
Original comment by evanpla...@gmail.com
on 2 Nov 2012 at 3:45
It's fixed in the repo source.
I'd push another pre-release but to my complete surprise Google's back-end is
experiencing an issue preventing me from pushing to the public repo.
Apparently, it's a known issue and I just have to wait for them to apply the
fix.
No custom separator/delimiter support yet so the 'Sir Henry SDB.slk) data set
still won't work. That's next on my todo list. As soon as it's done, the
release number will jump to 7.0 (finally).
In the mean time, feel free to grab the latest via git or through the online
repo browser.
One question, do you have any reservations against me using the data set you
provided in this bug as a sample? That's one fancy looking data set, I wish I
knew of a place to get more like it.
I managed to tweak your vis code into a fully functional demo. There's a minor
bug that is screwing up the UI (and I can't push the fix yet). Once it's fixed
I suggest you check it out.
Original comment by evanpla...@gmail.com
on 3 Nov 2012 at 2:39
I am glad I could help with your development.
I will check the data I sent you just to make sure there are no issues with
data protection. Serial numbers etc.
The file is from a Volvo penta marine engine log test. My plan is to have
the chart web app sit on my web site where engineers can drop in files to
create viz representations for easier analysis. Will send send you the link
once I upload the page.
Original comment by tribbleh...@gmail.com
on 3 Nov 2012 at 6:17
Gviz chart now set up.
http://www.rrandi.co.uk/testing.php
will be modifying in due time but for now it works.
Original comment by tribbleh...@gmail.com
on 3 Nov 2012 at 8:52
Nice. Works perfectly.
I ended up dropping the data table and file info in the demo but it is
essentially the same. I'm still waiting for Google to fix their issue so I
can't push to the public repo yet but apparently my last push finally went
through.
Here's the link:
http://code.google.com/p/jquery-csv/source/browse/examples/google-visualization.
html
Original comment by evanpla...@gmail.com
on 4 Nov 2012 at 4:07
Looks good.
Only problem with the data file conversion of the particular files i am
working with is the null values are all converted to zeros.
is there any way for them to stay at null?
The other files i use work brilliantly. A most excellent plug in.
Brian
Original comment by tribbleh...@gmail.com
on 4 Nov 2012 at 1:46
I wasn't quite sure about that particular detail. In retrospect, I guess
setting null makes more sense.
Still no push access here but you can make the change to your own source.
Change:
if(isNaN(integer)) {
return 0;
To:
if(isNaN(integer)) {
return '';
Original comment by evanpla...@gmail.com
on 4 Nov 2012 at 11:06
I remember now, nulls aren't considered valid data in Google Vis (and most
likely flot too).
It's kind of a gray area because casting a null '' value to a scalar in
Javascript should technically return NaN.
Your thoughts?
Original comment by evanpla...@gmail.com
on 5 Nov 2012 at 4:54
[deleted comment]
Have just looked at the gviz playground. It appears to accept the value 'null'
and '' in a data table but not as the last value of a row. it only accepts
'null' as the last value. Tried out on this page
http://code.google.com/apis/ajax/playground/?type=visualization#annotated_time_l
ine
don't know if that will help in my case.
Original comment by tribbleh...@gmail.com
on 6 Nov 2012 at 6:37
ah my error. only accepts 'null' as null value.
Original comment by tribbleh...@gmail.com
on 6 Nov 2012 at 6:42
More thoughts......
I am going to modify the code used on my web page to replace 0 with 'null'.
Change:
if(isNaN(integer)) {
return 0;
To:
if(isNaN(integer)) {
return 'null';
and let you know if it works.
Brian
Original comment by tribbleh...@gmail.com
on 7 Nov 2012 at 7:30
Well, technically 'null' represents a string not a null value. Try it without
the quotes to see if that works.
The whole implicit type system used by Javascript can be a pain sometimes when
it isn't obvious what type should be used.
Original comment by evanpla...@gmail.com
on 7 Nov 2012 at 12:17
Spot on. Null seems to work.
Have to try on a few of the files before I open the beer! Lol.
Original comment by tribbleh...@gmail.com
on 7 Nov 2012 at 12:20
Tested now with all files i can find that i hope to use. replacing the following
if(isNaN(integer)) {
return 0;
with
if(isNaN(integer)) {
return null;
works! now null entries are correctly recognised by gviz.
will this be an addition that you will add to the code or am i a 'special case'
and need to host the script myself? If I need to host it myself then i had
better swap from Yola hosting as they wont let me upload js files unless i
upgrade......
Original comment by tribbleh...@gmail.com
on 7 Nov 2012 at 5:19
Duh... I probably should have taken a look at the documentation first.
"Each cell in the table holds a value. Cells can have a null value, or a value
of the type specified by its column."
_Source: https://developers.google.com/chart/interactive/docs/reference_
It makes sense that type null represents a non-value. That is actually the
primary purpose for its existence because 0 is considered a value. Anyway, the
change has been incorporated into the latest commit of the public repo.
If you don't mind the risk that future changes could possibly break the code
temporarily, you could always link directly to the repo. That's basically what
I do in all of the example code.
Here's the link:
http://jquery-csv.googlecode.com/git/src/jquery.csv.js
This project is still somewhat unstable and prone to change (ie beta). When I
reach the 1.0 keystone I plan to lock-in the spec and provide a hosted
long-term release. Who knows, maybe one of the main jQuery CDNs will host a
copy so I won't have to.
Original comment by evanpla...@gmail.com
on 7 Nov 2012 at 11:16
Many thanks for the update. I understand regarding the beta state. Will
leave it linked for now. Hope you don't mind but I have borrowed your demo
code and modified for my site and given you and asgallant credit. Will be
modifying to accommodate other functions as needs arise. And where ever
possible making others aware of your work and wonderful code.
Original comment by tribbleh...@gmail.com
on 8 Nov 2012 at 6:45
Lol, no need to give me attribution in the demo code. If you didn't notice the
code you posted was based largely on what you originally posted. That saved a
lot of time that would have otherwise been spent trying to figure out the
Google Viz API.
All I did was clean up the styling to be more consistent with the rest of my
demos and wrapped it in a jQuery UI to make it look nice.
I appreciate the feedback, not only did you help identify some issues with the
core parser but also helped to refine the castToScalar functionality in a way
that will be more robust for re-use in the future.
Your feedback is really appreciated. It's users like you that help ensure that
projects like this can achieve a high level of quality.
Original comment by evanpla...@gmail.com
on 8 Nov 2012 at 2:35
Evening. Just catching up with projects I had to shelve and am now picking
back up.
Nice to see that this is still going. Have been using it quite a bit and am
now redesigning it to enable others at work to use it. got to be fool proof
and not complicated. lol.
Will keep you appraised.
Original comment by tribbleh...@gmail.com
on 23 Sep 2013 at 8:51
Original issue reported on code.google.com by
tribbleh...@gmail.com
on 24 Oct 2012 at 7:31