question

Aditya Prakash avatar image
0 Likes"
Aditya Prakash asked Phil BoBo edited

exporttable() exports incomplete table.

sample.fsm

Hi, I'm exporting a global table at the OnRunStop trigger, but exporttable() is exporting incomplete table. This problem doesn't occur for the first time, but after deleting the .csv file and re-running the model, this problem starts to occur. Attached is a sample model where I'm trying to export 15 row table, but it exports only 13 rows. Whats happening ?

FlexSim 16.1.0
exporting
pic.png (57.5 KiB)
sample.fsm (14.2 KiB)
5 |100000

Up to 12 attachments (including images) can be used with a maximum of 23.8 MiB each and 47.7 MiB total.

1 Answer

Jordan Johnson avatar image
1 Like"
Jordan Johnson answered Phil BoBo edited

It looks like there's a bug in the exporttable command in 16.1.0 (and 16.0.2), where it's using the number of columns as the number of rows in the table.

There are a couple possible workarounds. First, you could change your global table to use bundle data. Then exporttable works properly. The downside is that you can't have named rows for bundles.

If bundle data is not an option, you could use exportdataset. The downside there is that it doesn't export row or column headers.

A poor solution (but possibly adequate for your needs) would be to add two extra columns, so that your table is square.

Finally, you could use a script like this one (for non-bundle tables):

  1. // options of the command
  2. string fileName = concat(modeldir(), "sample.csv");
  3. treenode table = reftable("GlobalTable1");
  4. int printRowHeaders = 1;
  5. int printColHeaders = 0;
  6.  
  7. // additional options
  8. string itemSep = ",";
  9. string lineSep = "\n";
  10.  
  11. // precision defined by the model settings
  12. int precision = get(node("MAIN:/1/8/1/6"));
  13.  
  14. // logic for the command
  15. int rows = content(table);
  16. int cols = content(first(table));
  17.  
  18. int success = fileopen(fileName, "w");
  19. if (!success)
  20. return 0;
  21.  
  22. if (printRowHeaders) {
  23. for (int j = printColHeaders ? 0 : 1; j <= cols; j++) {
  24. if (j == 0 ) {
  25. fpt(itemSep);
  26. } else {
  27. string colHeader = getname(rank(first(table), j));
  28. fpt(colHeader);
  29. fpt(itemSep);
  30. }
  31. }
  32. fpt(lineSep);
  33. }
  34.  
  35. for (int i = 1; i <= rows; i++) {
  36. treenode rowNode = rank(table, i);
  37. for (int j = printColHeaders ? 0 : 1; j <= cols; j++) {
  38. if (j == 0 ) {
  39. fpt(getname(rowNode));
  40. fpt(itemSep);
  41. } else {
  42. treenode curCell = rank(rowNode, j);
  43. int datatype = getdatatype(curCell);
  44. switch (datatype) {
  45. case DATATYPE_STRING:
  46. fpt(gets(curCell));
  47. break;
  48. case DATATYPE_NUMBER:
  49. fpt(numtostring(get(curCell), 0, precision));
  50. break;
  51. }
  52. fpt(itemSep);
  53. }
  54. }
  55. fpt(lineSep);
  56. }
  57.  
  58. fileclose();
· 1
5 |100000

Up to 12 attachments (including images) can be used with a maximum of 23.8 MiB each and 47.7 MiB total.