Add symbol-info command
parent
613564b0f5
commit
f77a39ceb7
|
@ -225,3 +225,26 @@ def optsquote(config, symbol, df_output, date):
|
||||||
click.echo(df)
|
click.echo(df)
|
||||||
else:
|
else:
|
||||||
click.echo(colorize_json(quotes))
|
click.echo(colorize_json(quotes))
|
||||||
|
|
||||||
|
|
||||||
|
@cli.command()
|
||||||
|
@click.argument('tickers', nargs=-1, required=True)
|
||||||
|
@click.pass_obj
|
||||||
|
def symbol_info(config, tickers):
|
||||||
|
"""Print symbol quotes to the console
|
||||||
|
"""
|
||||||
|
# global opts
|
||||||
|
brokermod = config['brokermod']
|
||||||
|
|
||||||
|
quotes = trio.run(partial(core.symbol_info, brokermod, tickers))
|
||||||
|
if not quotes:
|
||||||
|
log.error(f"No quotes could be found for {tickers}?")
|
||||||
|
return
|
||||||
|
|
||||||
|
if len(quotes) < len(tickers):
|
||||||
|
syms = tuple(map(itemgetter('symbol'), quotes))
|
||||||
|
for ticker in tickers:
|
||||||
|
if ticker not in syms:
|
||||||
|
brokermod.log.warn(f"Could not find symbol {ticker}?")
|
||||||
|
|
||||||
|
click.echo(colorize_json(quotes))
|
||||||
|
|
|
@ -108,15 +108,3 @@ async def symbol_info(
|
||||||
"""
|
"""
|
||||||
async with brokermod.get_client() as client:
|
async with brokermod.get_client() as client:
|
||||||
return await client.symbol_info(symbol, **kwargs)
|
return await client.symbol_info(symbol, **kwargs)
|
||||||
|
|
||||||
|
|
||||||
async def symbol_search(
|
|
||||||
brokermod: ModuleType,
|
|
||||||
symbol: str,
|
|
||||||
**kwargs,
|
|
||||||
) -> Dict[str, Dict[str, Dict[str, Any]]]:
|
|
||||||
"""Return symbol info from broker.
|
|
||||||
"""
|
|
||||||
async with brokermod.get_client() as client:
|
|
||||||
# TODO: support multiple asset type concurrent searches.
|
|
||||||
return await client.search_stocks(symbol, **kwargs)
|
|
||||||
|
|
Loading…
Reference in New Issue