PINE LIBRARY

SIC_TICKER_DATA

215
The SIC Ticker Data is an advanced and efficient library for ticker-to-industry classification and sector analysis. Built with enterprise-grade performance optimizations, this library provides instant access to SIC codes, industry classifications, and peer company data for comprehensive market analysis.

Perfect for: Sector rotation strategies, peer analysis, portfolio diversification, market screening, and financial research tools.


The simple idea behind this library is to pull any data related to SIC number of any US stock market ticker provided by SEC in order to see the industry and also see the exact competitors of the ticker.

The library stores 3 types of data: SIC number, Ticker, and Industry name. What makes it very useful is that you can pull any one of this data using the other. For example, if you would like to know which tickers are inside a certain SIC, or what's the SIC number of a specific ticker, or even which tickers are inside a certain industry, you can use this library to pull this data. The idea for data inside this library is to be accessible in any direction possible as long as they're related to each other.

We've also published a simple indicator that uses this library in order to demonstrate the inner workings of this library.

The library stores thousands of tickers and their relevant SIC code and industry for your use and is constantly updated with new data when available. This is a large library but it is optimized to run as fast as possible. The previous unpublished versions would take over 40 seconds to load any data but the final public version here loads the data in less than 5 seconds.

🔍 Primary Lookup Functions

createDataStore()
Initialize the library with all pre-loaded data.
Pine Script®
store = data.createDataStore()


getSicByTicker(store, ticker)
Get SIC code for any ticker symbol.
Pine Script®
sic = data.getSicByTicker(store, "AAPL") // Returns: "3571"


getIndustryByTicker(store, ticker)
Get industry classification for any ticker.
Pine Script®
industry = data.getIndustryByTicker(store, "AAPL") // Returns: "Computer Hardware"


getTickersBySic(store, sic)
Get all companies in a specific SIC code.
Pine Script®
software = data.getTickersBySic(store, "7372") // Returns: "MSFT,GOOGL,META,V,MA,CRM,ADBE,ORCL,NOW,INTU"


getTickersByIndustry(store, industry)
Get all companies in an industry.
Pine Script®
retail = data.getTickersByIndustry(store, "Retail") // Returns: "AMZN,HD,WMT,TGT,COST,LOW"



📊 Array & Analysis Functions

getTickerArrayBySic(store, sic)
Get tickers as array for processing.
Pine Script®
techArray = data.getTickerArrayBySic(store, "7372") for i = 0 to array.size(techArray) - 1 ticker = array.get(techArray, i) // Process each tech company


getTickerCountBySic(store, sic)
Count companies in a sector (ultra-fast).
Pine Script®
pinescripttechCount = data.getTickerCountBySic(store, "7372") // Returns: 10



🎯 Utility Functions

tickerExists(store, ticker)
Check if ticker exists in database.
Pine Script®
exists = data.tickerExists(store, "AAPL") // Returns: true


tickerInSic(store, ticker, sic)
Check if ticker belongs to specific sector.
Pine Script®
isInTech = data.tickerInSic(store, "AAPL", "3571") // Returns: true



💡 Usage Examples

Example 1: Basic Ticker Lookup
Pine Script®
// @version=6 import EdgeTerminal/SIC_TICKER_DATA/1 as data indicator("Ticker Analysis", overlay=true) store = data.createDataStore() currentSic = data.getSicByTicker(store, syminfo.ticker) currentIndustry = data.getIndustryByTicker(store, syminfo.ticker) if barstate.islast and currentSic != "NOT_FOUND" label.new(bar_index, high, syminfo.ticker + "\nSIC: " + currentSic + "\nIndustry: " + currentIndustry)



Example 2: Sector Analysis
// version=6
import EdgeTerminal/SIC_TICKER_DATA/1 as data
indicator("Sector Comparison", overlay=false)
store = data.createDataStore()
// Compare sector sizes
techCount = data.getTickerCountBySic(store, "7372") // Software
financeCount = data.getTickerCountBySic(store, "6199") // Finance
healthCount = data.getTickerCountBySic(store, "2834") // Pharmaceutical
plot(techCount, title="Tech Companies", color=color.blue)
plot(financeCount, title="Finance Companies", color=color.green)
plot(healthCount, title="Health Companies", color=color.red)


Example 3: Peer Analysis
Pine Script®
// @version=6 import EdgeTerminal/SIC_TICKER_DATA/1 as data indicator("Find Competitors", overlay=true) store = data.createDataStore() currentSic = data.getSicByTicker(store, syminfo.ticker) if currentSic != "NOT_FOUND" competitors = data.getTickersBySic(store, currentSic) peerCount = data.getTickerCountBySic(store, currentSic) if barstate.islast label.new(bar_index, high, "Competitors (" + str.tostring(peerCount) + "):\n" + competitors)



Example 4: Portfolio Sector Allocation
Pine Script®
// @version=6 import EdgeTerminal/SIC_TICKER_DATA/1 as data indicator("Portfolio Analysis", overlay=false) store = data.createDataStore() // Analyze your portfolio's sector distribution portfolioTickers = array.from("AAPL", "MSFT", "GOOGL", "JPM", "JNJ") sectorCount = map.new<string, int>() for i = 0 to array.size(portfolioTickers) - 1 ticker = array.get(portfolioTickers, i) industry = data.getIndustryByTicker(store, ticker) if industry != "NOT_FOUND" currentCount = map.get(sectorCount, industry) newCount = na(currentCount) ? 1 : currentCount + 1 map.put(sectorCount, industry, newCount)




🔧 Advanced Feature
You can also bulk load data for large data sets like this:
Pine Script®
// Pre-format your data as pipe-separated string bulkData = "AAPL:3571:Computer Hardware|MSFT:7372:Software|GOOGL:7372:Software" store = data.createDataStoreFromBulk(bulkData)

Aviso legal

As informações e publicações não devem ser e não constituem conselhos ou recomendações financeiras, de investimento, de negociação ou de qualquer outro tipo, fornecidas ou endossadas pela TradingView. Leia mais em Termos de uso.