F#:打印完整列表而不显式循环

时间:2011-05-02 09:58:47

标签: f#

是否可以在F#中打印数据结构而不缩写长列表?

使用printf,我似乎只能打印前100个元素:

\> let l = [1 .. 200];;

val l : int list =
  [1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15; 16; 17; 18; 19; 20; 21;
   22; 23; 24; 25; 26; 27; 28; 29; 30; 31; 32; 33; 34; 35; 36; 37; 38; 39; 40;
   41; 42; 43; 44; 45; 46; 47; 48; 49; 50; 51; 52; 53; 54; 55; 56; 57; 58; 59;
   60; 61; 62; 63; 64; 65; 66; 67; 68; 69; 70; 71; 72; 73; 74; 75; 76; 77; 78;
   79; 80; 81; 82; 83; 84; 85; 86; 87; 88; 89; 90; 91; 92; 93; 94; 95; 96; 97;
   98; 99; 100; ...]

\> printf "%A\n" l;;   
[1; 2; 3; 4; 5; 6; 7; 8; 9; 10; 11; 12; 13; 14; 15; 16; 17; 18; 19; 20; 21; 22;
 23; 24; 25; 26; 27; 28; 29; 30; 31; 32; 33; 34; 35; 36; 37; 38; 39; 40; 41; 42;
 43; 44; 45; 46; 47; 48; 49; 50; 51; 52; 53; 54; 55; 56; 57; 58; 59; 60; 61; 62;
 63; 64; 65; 66; 67; 68; 69; 70; 71; 72; 73; 74; 75; 76; 77; 78; 79; 80; 81; 82;
 83; 84; 85; 86; 87; 88; 89; 90; 91; 92; 93; 94; 95; 96; 97; 98; 99; 100; ...]

val it : unit = ()

在这种情况下,可以遍历元素,但是,在更复杂的数据结构中,有必要分解结构以允许访问列表。

例如,是否可以完整地打印以下结构而不将其分解为单个列表:

\> let l = ([1 ..200], [1..200]);;

1 个答案:

答案 0 :(得分:4)

您可以使用PrintLength对象的fsi属性指定打印列表的最大长度。它不允许您直接指定无穷大,但您可以使用:

fsi.PrintLength <- System.Int32.MaxValue

有几个类似的属性,但它们没有很好地记录(参见MSDN page),所以你可能需要进行一些实验。