

<?xml version="1.0"?>
<oembed><version>1.0</version><provider_name>Code and Stats</provider_name><provider_url>https://blog.hwr-berlin.de/codeandstats</provider_url><author_name>Markus L&#xF6;cher</author_name><author_url>https://blog.hwr-berlin.de/codeandstats/author/loecher/</author_url><title>Grouping Duplicates - Code and Stats</title><type>rich</type><width>600</width><height>338</height><html>&lt;blockquote class="wp-embedded-content" data-secret="1qdwheD952"&gt;&lt;a href="https://blog.hwr-berlin.de/codeandstats/identifying-duplicates/"&gt;Grouping Duplicates&lt;/a&gt;&lt;/blockquote&gt;&lt;iframe sandbox="allow-scripts" security="restricted" src="https://blog.hwr-berlin.de/codeandstats/identifying-duplicates/embed/#?secret=1qdwheD952" width="600" height="338" title="&#x201C;Grouping Duplicates&#x201D; &#x2014; Code and Stats" data-secret="1qdwheD952" frameborder="0" marginwidth="0" marginheight="0" scrolling="no" class="wp-embedded-content"&gt;&lt;/iframe&gt;&lt;script&gt;
/*! This file is auto-generated */
!function(d,l){"use strict";l.querySelector&amp;&amp;d.addEventListener&amp;&amp;"undefined"!=typeof URL&amp;&amp;(d.wp=d.wp||{},d.wp.receiveEmbedMessage||(d.wp.receiveEmbedMessage=function(e){var t=e.data;if((t||t.secret||t.message||t.value)&amp;&amp;!/[^a-zA-Z0-9]/.test(t.secret)){for(var s,r,n,a=l.querySelectorAll('iframe[data-secret="'+t.secret+'"]'),o=l.querySelectorAll('blockquote[data-secret="'+t.secret+'"]'),c=new RegExp("^https?:$","i"),i=0;i&lt;o.length;i++)o[i].style.display="none";for(i=0;i&lt;a.length;i++)s=a[i],e.source===s.contentWindow&amp;&amp;(s.removeAttribute("style"),"height"===t.message?(1e3&lt;(r=parseInt(t.value,10))?r=1e3:~~r&lt;200&amp;&amp;(r=200),s.height=r):"link"===t.message&amp;&amp;(r=new URL(s.getAttribute("src")),n=new URL(t.value),c.test(n.protocol))&amp;&amp;n.host===r.host&amp;&amp;l.activeElement===s&amp;&amp;(d.top.location.href=t.value))}},d.addEventListener("message",d.wp.receiveEmbedMessage,!1),l.addEventListener("DOMContentLoaded",function(){for(var e,t,s=l.querySelectorAll("iframe.wp-embedded-content"),r=0;r&lt;s.length;r++)(t=(e=s[r]).getAttribute("data-secret"))||(t=Math.random().toString(36).substring(2,12),e.src+="#?secret="+t,e.setAttribute("data-secret",t)),e.contentWindow.postMessage({message:"ready",secret:t},"*")},!1)))}(window,document);
//# sourceURL=https://blog.hwr-berlin.de/codeandstats/wp-includes/js/wp-embed.min.js
&lt;/script&gt;
</html><description>Both base R and data.table offer their duplicated() functions which are useful if your main goals is to identify and possibly delete duplicates. For example BirthDay &lt;- as.Date(c(rep("1970-08-08",2), "1950-03-01", "1963-12-10",rep("1968-10-18",2))) HomeTown = c(rep("New Brunswick,NJ",2),"Springfield,OH","Buffalo,NY",rep("Portland,OR",2)) df &lt;-data.frame(BirthDay,HomeTown) duplicated(df) ## [1] FALSE TRUE FALSE FALSE FALSE TRUE df[duplicated(df), ] ## BirthDay HomeTown ## 2 1970-08-08 New Brunswick,NJ &hellip; Continue reading</description></oembed>
