blob: ba4ef308d0bcb8dedc06501ad3293be14e42a8b9 [file] [log] [blame]
<!-- Generated by pkgdown: do not edit by hand -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Table class — Table • Arrow R Package</title>
<!-- jquery -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
<!-- Bootstrap -->
<link href="https://cdnjs.cloudflare.com/ajax/libs/bootswatch/3.4.0/cosmo/bootstrap.min.css" rel="stylesheet" crossorigin="anonymous" />
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js" integrity="sha256-nuL8/2cJ5NDSSwnKD8VqreErSWHtnEP9E7AySL+1ev4=" crossorigin="anonymous"></script>
<!-- bootstrap-toc -->
<link rel="stylesheet" href="../bootstrap-toc.css">
<script src="../bootstrap-toc.js"></script>
<!-- Font Awesome icons -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.12.1/css/all.min.css" integrity="sha256-mmgLkCYLUQbXn0B1SRqzHar6dCnv9oZFPEC1g1cwlkk=" crossorigin="anonymous" />
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.12.1/css/v4-shims.min.css" integrity="sha256-wZjR52fzng1pJHwx4aV2AO3yyTOXrcDW7jBpJtTwVxw=" crossorigin="anonymous" />
<!-- clipboard.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.6/clipboard.min.js" integrity="sha256-inc5kl9MA1hkeYUt+EC3BhlIgyp/2jDIyBLS6k3UxPI=" crossorigin="anonymous"></script>
<!-- headroom.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.11.0/headroom.min.js" integrity="sha256-AsUX4SJE1+yuDu5+mAVzJbuYNPHj/WroHuZ8Ir/CkE0=" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/headroom/0.11.0/jQuery.headroom.min.js" integrity="sha256-ZX/yNShbjqsohH1k95liqY9Gd8uOiE1S4vZc+9KQ1K4=" crossorigin="anonymous"></script>
<!-- pkgdown -->
<link href="../pkgdown.css" rel="stylesheet">
<script src="../pkgdown.js"></script>
<script src="../extra.js"></script>
<meta property="og:title" content="Table class — Table" />
<meta property="og:description" content="A Table is a sequence of chunked arrays. They
have a similar interface to record batches, but they can be
composed from multiple record batches or chunked arrays." />
<!-- mathjax -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/MathJax.js" integrity="sha256-nvJJv9wWKEm88qvoQl9ekL2J+k/RWIsaSScxxlsrv8k=" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/mathjax/2.7.5/config/TeX-AMS-MML_HTMLorMML.js" integrity="sha256-84DKXVJXs0/F8OTMzX4UR909+jtl4G7SPypPavF+GfA=" crossorigin="anonymous"></script>
<!--[if lt IE 9]>
<script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script>
<script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
<![endif]-->
<!-- Matomo -->
<script>
var _paq = window._paq = window._paq || [];
/* tracker methods like "setCustomDimension" should be called before "trackPageView" */
_paq.push(["setDoNotTrack", true]);
_paq.push(["disableCookies"]);
_paq.push(['trackPageView']);
_paq.push(['enableLinkTracking']);
(function() {
var u="https://analytics.apache.org/";
_paq.push(['setTrackerUrl', u+'matomo.php']);
_paq.push(['setSiteId', '20']);
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s);
})();
</script>
<!-- End Matomo Code -->
</head>
<body data-spy="scroll" data-target="#toc">
<div class="container template-reference-topic">
<header>
<div class="navbar navbar-default navbar-fixed-top" role="navigation">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<span class="navbar-brand">
<a class="navbar-link" href="../index.html">Arrow R Package</a>
<span class="version label label-default" data-toggle="tooltip" data-placement="bottom" title="Released version">4.0.1</span>
</span>
</div>
<div id="navbar" class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li>
<a href="https://arrow.apache.org/">❯❯❯</a>
</li>
<li>
<a href="../articles/arrow.html">Get started</a>
</li>
<li>
<a href="../reference/index.html">Reference</a>
</li>
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">
Articles
<span class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu">
<li>
<a href="../articles/install.html">Installing the Arrow Package on Linux</a>
</li>
<li>
<a href="../articles/dataset.html">Working with Arrow Datasets and dplyr</a>
</li>
<li>
<a href="../articles/fs.html">Working with Cloud Storage (S3)</a>
</li>
<li>
<a href="../articles/python.html">Apache Arrow in Python and R with reticulate</a>
</li>
<li>
<a href="../articles/flight.html">Connecting to Flight RPC Servers</a>
</li>
<li>
<a href="../articles/developing.html">Arrow R Developer Guide</a>
</li>
</ul>
</li>
<li>
<a href="../news/index.html">Changelog</a>
</li>
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">
Project docs
<span class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu">
<li>
<a href="https://arrow.apache.org/docs/format/README.html">Specification</a>
</li>
<li>
<a href="https://arrow.apache.org/docs/c_glib">C GLib</a>
</li>
<li>
<a href="https://arrow.apache.org/docs/cpp">C++</a>
</li>
<li>
<a href="https://arrow.apache.org/docs/java">Java</a>
</li>
<li>
<a href="https://arrow.apache.org/docs/js">JavaScript</a>
</li>
<li>
<a href="https://arrow.apache.org/docs/python">Python</a>
</li>
<li>
<a href="../index.html">R</a>
</li>
</ul>
</li>
</ul>
<ul class="nav navbar-nav navbar-right">
</ul>
</div><!--/.nav-collapse -->
</div><!--/.container -->
</div><!--/.navbar -->
</header>
<div class="row">
<div class="col-md-9 contents">
<div class="page-header">
<h1>Table class</h1>
<small class="dont-index">Source: <a href='https://github.com/apache/arrow/blob/master/r/R/table.R'><code>R/table.R</code></a></small>
<div class="hidden name"><code>Table.Rd</code></div>
</div>
<div class="ref-description">
<p>A Table is a sequence of <a href='ChunkedArray.html'>chunked arrays</a>. They
have a similar interface to <a href='RecordBatch.html'>record batches</a>, but they can be
composed from multiple record batches or chunked arrays.</p>
</div>
<h2 class="hasAnchor" id="factory"><a class="anchor" href="#factory"></a>Factory</h2>
<p>The <code>Table$create()</code> function takes the following arguments:</p><ul>
<li><p><code>...</code> arrays, chunked arrays, or R vectors, with names; alternatively,
an unnamed series of <a href='RecordBatch.html'>record batches</a> may also be provided,
which will be stacked as rows in the table.</p></li>
<li><p><code>schema</code> a <a href='Schema.html'>Schema</a>, or <code>NULL</code> (the default) to infer the schema from
the data in <code>...</code></p></li>
</ul>
<h2 class="hasAnchor" id="s-methods-and-usage"><a class="anchor" href="#s-methods-and-usage"></a>S3 Methods and Usage</h2>
<p>Tables are data-frame-like, and many methods you expect to work on
a <code>data.frame</code> are implemented for <code>Table</code>. This includes <code><a href='https://rdrr.io/r/base/Extract.html'>[</a></code>, <code><a href='https://rdrr.io/r/base/Extract.html'>[[</a></code>,
<code><a href='https://rdrr.io/r/base/Extract.html'>$</a></code>, <code>names</code>, <code>dim</code>, <code>nrow</code>, <code>ncol</code>, <code>head</code>, and <code>tail</code>. You can also pull
the data from an Arrow table into R with <code><a href='https://rdrr.io/r/base/as.data.frame.html'>as.data.frame()</a></code>. See the
examples.</p>
<p>A caveat about the <code><a href='https://rdrr.io/r/base/Extract.html'>$</a></code> method: because <code>Table</code> is an <code>R6</code> object,
<code><a href='https://rdrr.io/r/base/Extract.html'>$</a></code> is also used to access the object's methods (see below). Methods take
precedence over the table's columns. So, <code>tab$Slice</code> would return the
"Slice" method function even if there were a column in the table called
"Slice".</p>
<h2 class="hasAnchor" id="r-methods"><a class="anchor" href="#r-methods"></a>R6 Methods</h2>
<p>In addition to the more R-friendly S3 methods, a <code>Table</code> object has
the following R6 methods that map onto the underlying C++ methods:</p><ul>
<li><p><code>$column(i)</code>: Extract a <code>ChunkedArray</code> by integer position from the table</p></li>
<li><p><code>$ColumnNames()</code>: Get all column names (called by <code><a href='https://rdrr.io/r/base/names.html'>names(tab)</a></code>)</p></li>
<li><p><code>$RenameColumns(value)</code>: Set all column names (called by <code>names(tab) &lt;- value</code>)</p></li>
<li><p><code>$GetColumnByName(name)</code>: Extract a <code>ChunkedArray</code> by string name</p></li>
<li><p><code>$field(i)</code>: Extract a <code>Field</code> from the table schema by integer position</p></li>
<li><p><code>$SelectColumns(indices)</code>: Return new <code>Table</code> with specified columns, expressed as 0-based integers.</p></li>
<li><p><code>$Slice(offset, length = NULL)</code>: Create a zero-copy view starting at the
indicated integer offset and going for the given length, or to the end
of the table if <code>NULL</code>, the default.</p></li>
<li><p><code>$Take(i)</code>: return an <code>Table</code> with rows at positions given by
integers <code>i</code>. If <code>i</code> is an Arrow <code>Array</code> or <code>ChunkedArray</code>, it will be
coerced to an R vector before taking.</p></li>
<li><p><code>$Filter(i, keep_na = TRUE)</code>: return an <code>Table</code> with rows at positions where logical
vector or Arrow boolean-type <code>(Chunked)Array</code> <code>i</code> is <code>TRUE</code>.</p></li>
<li><p><code>$SortIndices(names, descending = FALSE)</code>: return an <code>Array</code> of integer row
positions that can be used to rearrange the <code>Table</code> in ascending or descending
order by the first named column, breaking ties with further named columns.
<code>descending</code> can be a logical vector of length one or of the same length as
<code>names</code>.</p></li>
<li><p><code>$serialize(output_stream, ...)</code>: Write the table to the given
<a href='OutputStream.html'>OutputStream</a></p></li>
<li><p><code>$cast(target_schema, safe = TRUE, options = cast_options(safe))</code>: Alter
the schema of the record batch.</p></li>
</ul>
<p>There are also some active bindings:</p><ul>
<li><p><code>$num_columns</code></p></li>
<li><p><code>$num_rows</code></p></li>
<li><p><code>$schema</code></p></li>
<li><p><code>$metadata</code>: Returns the key-value metadata of the <code>Schema</code> as a named list.
Modify or replace by assigning in (<code>tab$metadata &lt;- new_metadata</code>).
All list elements are coerced to string. See <code><a href='Schema.html'>schema()</a></code> for more information.</p></li>
<li><p><code>$columns</code>: Returns a list of <code>ChunkedArray</code>s</p></li>
</ul>
<h2 class="hasAnchor" id="examples"><a class="anchor" href="#examples"></a>Examples</h2>
<pre class="examples"><div class='input'><span class='co'># \donttest{</span>
<span class='va'>tab</span> <span class='op'>&lt;-</span> <span class='va'>Table</span><span class='op'>$</span><span class='fu'>create</span><span class='op'>(</span>name <span class='op'>=</span> <span class='fu'><a href='https://rdrr.io/r/base/colnames.html'>rownames</a></span><span class='op'>(</span><span class='va'>mtcars</span><span class='op'>)</span>, <span class='va'>mtcars</span><span class='op'>)</span>
<span class='fu'><a href='https://rdrr.io/r/base/dim.html'>dim</a></span><span class='op'>(</span><span class='va'>tab</span><span class='op'>)</span>
</div><div class='output co'>#&gt; [1] 32 12</div><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/dim.html'>dim</a></span><span class='op'>(</span><span class='fu'><a href='https://rdrr.io/r/utils/head.html'>head</a></span><span class='op'>(</span><span class='va'>tab</span><span class='op'>)</span><span class='op'>)</span>
</div><div class='output co'>#&gt; [1] 6 12</div><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/names.html'>names</a></span><span class='op'>(</span><span class='va'>tab</span><span class='op'>)</span>
</div><div class='output co'>#&gt; [1] "name" "mpg" "cyl" "disp" "hp" "drat" "wt" "qsec" "vs" "am"
#&gt; [11] "gear" "carb"</div><div class='input'><span class='va'>tab</span><span class='op'>$</span><span class='va'>mpg</span>
</div><div class='output co'>#&gt; ChunkedArray
#&gt; [
#&gt; [
#&gt; 21,
#&gt; 21,
#&gt; 22.8,
#&gt; 21.4,
#&gt; 18.7,
#&gt; 18.1,
#&gt; 14.3,
#&gt; 24.4,
#&gt; 22.8,
#&gt; 19.2,
#&gt; ...
#&gt; 15.2,
#&gt; 13.3,
#&gt; 19.2,
#&gt; 27.3,
#&gt; 26,
#&gt; 30.4,
#&gt; 15.8,
#&gt; 19.7,
#&gt; 15,
#&gt; 21.4
#&gt; ]
#&gt; ]</div><div class='input'><span class='va'>tab</span><span class='op'>[[</span><span class='st'>"cyl"</span><span class='op'>]</span><span class='op'>]</span>
</div><div class='output co'>#&gt; ChunkedArray
#&gt; [
#&gt; [
#&gt; 6,
#&gt; 6,
#&gt; 4,
#&gt; 6,
#&gt; 8,
#&gt; 6,
#&gt; 8,
#&gt; 4,
#&gt; 4,
#&gt; 6,
#&gt; ...
#&gt; 8,
#&gt; 8,
#&gt; 8,
#&gt; 4,
#&gt; 4,
#&gt; 4,
#&gt; 8,
#&gt; 6,
#&gt; 8,
#&gt; 4
#&gt; ]
#&gt; ]</div><div class='input'><span class='fu'><a href='https://rdrr.io/r/base/as.data.frame.html'>as.data.frame</a></span><span class='op'>(</span><span class='va'>tab</span><span class='op'>[</span><span class='fl'>4</span><span class='op'>:</span><span class='fl'>8</span>, <span class='fu'><a href='https://rdrr.io/r/base/c.html'>c</a></span><span class='op'>(</span><span class='st'>"gear"</span>, <span class='st'>"hp"</span>, <span class='st'>"wt"</span><span class='op'>)</span><span class='op'>]</span><span class='op'>)</span>
</div><div class='output co'>#&gt; <span style='color: #949494;'># A tibble: 5 x 3</span>
#&gt; gear hp wt
#&gt; <span style='color: #949494; font-style: italic;'>&lt;dbl&gt;</span> <span style='color: #949494; font-style: italic;'>&lt;dbl&gt;</span> <span style='color: #949494; font-style: italic;'>&lt;dbl&gt;</span>
#&gt; <span style='color: #BCBCBC;'>1</span> 3 110 3.22
#&gt; <span style='color: #BCBCBC;'>2</span> 3 175 3.44
#&gt; <span style='color: #BCBCBC;'>3</span> 3 105 3.46
#&gt; <span style='color: #BCBCBC;'>4</span> 3 245 3.57
#&gt; <span style='color: #BCBCBC;'>5</span> 4 62 3.19</div><div class='input'><span class='co'># }</span>
</div></pre>
</div>
<div class="col-md-3 hidden-xs hidden-sm" id="pkgdown-sidebar">
<nav id="toc" data-toggle="toc" class="sticky-top">
<h2 data-toc-skip>Contents</h2>
</nav>
</div>
</div>
<footer>
<div class="copyright">
<p>Developed by Neal Richardson, Ian Cook, Jonathan Keane, Romain François, Jeroen Ooms, Apache Arrow.</p>
</div>
<div class="pkgdown">
<p>Site built with <a href="https://pkgdown.r-lib.org/">pkgdown</a> 1.6.1.</p>
</div>
</footer>
</div>
<script type="text/javascript" src="/docs/_static/versionwarning.js"></script> </body>
</html>