{"id":41388,"date":"2026-06-16T05:27:12","date_gmt":"2026-06-16T03:27:12","guid":{"rendered":"https:\/\/www.graviton.at\/letterswaplibrary\/every-us-etfs-full-holdings-and-operational-census-is-public-machine-readable-sec-data-n-port-n-cen-and-underused\/"},"modified":"2026-06-16T05:27:12","modified_gmt":"2026-06-16T03:27:12","slug":"every-us-etfs-full-holdings-and-operational-census-is-public-machine-readable-sec-data-n-port-n-cen-and-underused","status":"publish","type":"post","link":"https:\/\/www.graviton.at\/letterswaplibrary\/every-us-etfs-full-holdings-and-operational-census-is-public-machine-readable-sec-data-n-port-n-cen-and-underused\/","title":{"rendered":"Every US ETF&#8217;s Full Holdings And Operational Census Is Public, Machine-readable SEC Data (N-PORT + N-CEN) And Underused"},"content":{"rendered":"<p><!-- SC_OFF --><\/p>\n<div class=\"md\">\n<p><strong>Sharing a data source that&#8217;s surprisingly underused for fund analysis<\/strong>: the SEC&#8217;s N-PORT and N-CEN filings on EDGAR. <\/p>\n<p>&#8211; <strong>N-PORT<\/strong> (quarterly, structured XML): every fund&#8217;s complete position list with weights, share counts, CUSIP\/ISIN, country of domicile, ASC 820 fair-value level, monthly returns, and monthly creation\/redemption flows.<br \/> &#8211; <strong>N-CEN<\/strong> (annual, structured XML): tracking difference vs benchmark (gross AND net of fees), securities-lending activity, in-kind creation\/redemption percentages, per-broker commissions, and the full service-provider roster. <\/p>\n<p><strong>What you can pull out without any paid vendor:<\/strong><br \/> &#8211; Index-fund tracking split into replication vs cost. VOO 2025 was -0.4 bps vs the S&amp;P 500 gross of fees, -16.9 bps net.<br \/> &#8211; True per-CUSIP overlap between funds. SPY vs VOO is 476 shared holdings, ~97% by weight.<br \/> &#8211; Issuer-domicile reality checks. SPY is ~97% US, ~3% Ireland\/Switzerland\/Bermuda\/Netherlands. <\/p>\n<p><strong>Gotchas:<\/strong> positions are keyed on CUSIP (not ticker), so you need a CUSIP-to-ticker map to join to anything else; unit investment trusts (like SPY) file lighter N-CEN sections than open-end funds (like VOO), so some fields are legitimately empty; and the public lag is ~60 days after quarter-end. <\/p>\n<p>The <strong>StockFit API<\/strong> does the XML parsing and CUSIP resolution if you don&#8217;t want to build it yourself. <\/p>\n<p>Not financial advice, just pointing at the filings.<\/p>\n<\/div>\n<p><!-- SC_ON -->   submitted by   <a href=\"https:\/\/www.reddit.com\/user\/Either_Door_5500\"> \/u\/Either_Door_5500 <\/a> <br \/> <span><a href=\"https:\/\/www.reddit.com\/r\/datasets\/comments\/1u712kn\/every_us_etfs_full_holdings_and_operational\/\">[link]<\/a><\/span>   <span><a href=\"https:\/\/www.reddit.com\/r\/datasets\/comments\/1u712kn\/every_us_etfs_full_holdings_and_operational\/\">[comments]<\/a><\/span><\/p><div class='watch-action'><div class='watch-position align-right'><div class='action-like'><a class='lbg-style1 like-41388 jlk' href='javascript:void(0)' data-task='like' data-post_id='41388' data-nonce='1c691d6265' rel='nofollow'><img class='wti-pixel' src='https:\/\/www.graviton.at\/letterswaplibrary\/wp-content\/plugins\/wti-like-post\/images\/pixel.gif' title='Like' \/><span class='lc-41388 lc'>0<\/span><\/a><\/div><\/div> <div class='status-41388 status align-right'><\/div><\/div><div class='wti-clear'><\/div>","protected":false},"excerpt":{"rendered":"<p>Sharing a data source that&#8217;s surprisingly underused for fund analysis: the SEC&#8217;s N-PORT and N-CEN filings on&#8230;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[85],"tags":[],"class_list":["post-41388","post","type-post","status-publish","format-standard","hentry","category-datatards","wpcat-85-id"],"_links":{"self":[{"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/posts\/41388","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/comments?post=41388"}],"version-history":[{"count":0,"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/posts\/41388\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/media?parent=41388"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/categories?post=41388"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.graviton.at\/letterswaplibrary\/wp-json\/wp\/v2\/tags?post=41388"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}