Smart expansion of Spanish legal acronyms. 646 verified acronyms from RAE, BOE and DPEJ. | Expansión inteligente de siglas legales españolas.
Project description
Siglas legales españolas para documentos jurídicos
646 siglas legales españolas verificadas | Expansión inteligente para textos jurídicos
¿Qué hace este paquete?
legal-expand es una librería Python que expande automáticamente siglas legales en textos jurídicos españoles, añadiendo su significado completo entre paréntesis para facilitar la comprensión.
Ejemplo:
Entrada: "La AEAT notifica el IVA según el art. 123 del CC"
Salida: "La AEAT (Agencia Estatal de Administración Tributaria) notifica el IVA (Impuesto sobre el Valor Añadido) según el art. (Artículo) 123 del CC (Código Civil)"
Características principales
- 646 siglas verificadas de leyes, organismos, impuestos, tribunales y procedimientos
- Fuentes oficiales: RAE, DPEJ, BOE y legislación vigente
- Detección inteligente de variantes (AEAT, A.E.A.T., A.E.A.T)
- Múltiples formatos: texto plano, HTML semántico, JSON estructurado
- Documentos largos optimizados: expandir solo primera ocurrencia para evitar repeticiones
- Control granular: configuración global + override por llamada
- Zero dependencies: sin dependencias en runtime
- Type hints completos: tipos para autocompletado en IDEs
- Python 3.9+: compatible con versiones modernas
Demo interactiva
Prueba el paquete sin instalar nada:
El notebook incluye ejemplos de todos los casos de uso: expansión básica, formatos de salida, configuración global, documentos reales y herramientas interactivas.
Índice
- Demo interactiva
- Instalación
- Uso básico
- Formatos de salida
- Control global y override
- Opciones avanzadas
- Manejo de duplicados
- Funciones auxiliares
- Uso en frameworks
- Casos de uso completos
- Uso en backend para LLMs
- Protección de contextos
- Extensibilidad
- API completa
- Siglas incluidas
- Rendimiento
- Compatibilidad
- Fuentes de las siglas
- Contribuir
- Licencia
Instalación
pip install legal-expand
Uso básico
Expansión simple
El caso de uso más común es expandir siglas en un texto legal. El paquete detecta automáticamente las siglas y añade su significado entre paréntesis.
from legal_expand import expandir_siglas
texto = 'La AEAT notifica el IVA'
resultado = expandir_siglas(texto)
print(resultado)
# Salida: 'La AEAT (Agencia Estatal de Administración Tributaria) notifica el IVA (Impuesto sobre el Valor Añadido)'
Expansión de múltiples siglas
El paquete puede procesar textos complejos con múltiples siglas diferentes, manteniendo la estructura y formato original del texto.
texto = 'Según el art. 123 del CC y la LEC, la AEAT debe procesar el BOE.'
resultado = expandir_siglas(texto)
print(resultado)
# Salida: 'Según el art. (Artículo) 123 del CC (Código Civil) y la LEC (Ley de Enjuiciamiento Civil),
# la AEAT (Agencia Estatal de Administración Tributaria) debe procesar el BOE (Boletín Oficial del Estado).'
Detección de variantes
El sistema detecta automáticamente variantes de siglas con o sin puntos, mayúsculas/minúsculas, y espacios internos.
# Todas estas variantes se detectan y expanden correctamente:
expandir_siglas('El art. 5 establece')
# Salida: 'El art. (Artículo) 5 establece'
expandir_siglas('El art 5 establece') # Sin punto
# Salida: 'El art (Artículo) 5 establece'
expandir_siglas('La AEAT notifica')
# Salida: 'La AEAT (Agencia Estatal de Administración Tributaria) notifica'
expandir_siglas('La A.E.A.T. notifica') # Con puntos
# Salida: 'La A.E.A.T. (Agencia Estatal de Administración Tributaria) notifica'
Formatos de salida
Formato de texto plano (por defecto)
El formato de texto plano añade el significado entre paréntesis inmediatamente después de cada sigla.
resultado = expandir_siglas('La AEAT notifica el IVA')
# Salida: 'La AEAT (Agencia Estatal de Administración Tributaria) notifica el IVA (Impuesto sobre el Valor Añadido)'
Formato HTML semántico
El formato HTML utiliza la etiqueta <abbr> con el atributo title, proporcionando tooltips nativos del navegador.
from legal_expand import expandir_siglas, ExpansionOptions
resultado = expandir_siglas('La AEAT notifica', ExpansionOptions(format='html'))
print(resultado)
# Salida: 'La <abbr title="Agencia Estatal de Administración Tributaria">AEAT</abbr> (Agencia Estatal de Administración Tributaria) notifica'
Uso en aplicaciones web (Flask, Django, FastAPI):
from flask import render_template_string
from legal_expand import expandir_siglas, ExpansionOptions
@app.route('/documento/<id>')
def documento(id):
texto = obtener_documento(id)
html_expandido = expandir_siglas(texto, ExpansionOptions(format='html'))
return render_template_string('<div>{{ contenido|safe }}</div>', contenido=html_expandido)
Formato estructurado (objeto)
El formato estructurado devuelve un objeto con metadata completa sobre las siglas encontradas.
from legal_expand import expandir_siglas, ExpansionOptions
resultado = expandir_siglas('AEAT y BOE', ExpansionOptions(format='structured'))
print(resultado.original_text) # 'AEAT y BOE'
print(resultado.expanded_text) # 'AEAT (Agencia...) y BOE (Boletín...)'
print(resultado.stats.total_expanded) # 2
for acronym in resultado.acronyms:
print(f"{acronym.acronym} → {acronym.expansion}")
Caso de uso - Análisis de documento:
analisis = expandir_siglas(documento, ExpansionOptions(format='structured'))
print(f"Documento procesado:")
print(f"- Siglas encontradas: {analisis.stats.total_acronyms_found}")
print(f"- Siglas expandidas: {analisis.stats.total_expanded}")
print(f"- Siglas ambiguas no expandidas: {analisis.stats.ambiguous_not_expanded}")
for sigla in analisis.acronyms:
print(f" • {sigla.acronym} → {sigla.expansion}")
Control global y override
Configuración global
Puedes configurar el comportamiento del paquete globalmente para toda tu aplicación.
from legal_expand import configurar_globalmente, expandir_siglas, GlobalConfig, ExpansionOptions
# Configurar opciones por defecto para toda la aplicación
configurar_globalmente(GlobalConfig(
enabled=True,
default_options=ExpansionOptions(
format='html',
expand_only_first=True
)
))
# Ahora todas las llamadas usarán estas opciones por defecto
expandir_siglas('AEAT y BOE') # Usará format='html' y expand_only_first=True
Desactivación global
Puedes desactivar la expansión globalmente.
from legal_expand import configurar_globalmente, expandir_siglas, GlobalConfig
# Desactivar expansión globalmente
configurar_globalmente(GlobalConfig(enabled=False))
expandir_siglas('La AEAT notifica el IVA')
# Salida: 'La AEAT notifica el IVA' (sin expandir)
Override de configuración global
El parámetro force_expansion permite anular la configuración global para llamadas específicas.
from legal_expand import configurar_globalmente, expandir_siglas, GlobalConfig, ExpansionOptions
configurar_globalmente(GlobalConfig(enabled=False))
# No se expande (respeta configuración global)
expandir_siglas('La AEAT notifica')
# Salida: 'La AEAT notifica'
# Forzar expansión aunque esté desactivado globalmente
expandir_siglas('La AEAT notifica', ExpansionOptions(force_expansion=True))
# Salida: 'La AEAT (Agencia Estatal de Administración Tributaria) notifica'
# Forzar NO expansión aunque esté activado globalmente
configurar_globalmente(GlobalConfig(enabled=True))
expandir_siglas('La AEAT notifica', ExpansionOptions(force_expansion=False))
# Salida: 'La AEAT notifica'
Resetear configuración
Restaura la configuración a sus valores por defecto.
from legal_expand import resetear_configuracion
# Después de múltiples configuraciones...
resetear_configuracion()
# Ahora todo vuelve a: enabled=True, format='plain', etc.
Opciones avanzadas
Expandir solo primera ocurrencia
Ideal para documentos largos (sentencias, contratos, informes de 100+ páginas). Con expand_only_first=True, solo se expande la primera aparición de cada sigla.
from legal_expand import expandir_siglas, ExpansionOptions
documento_largo = """
La AEAT ha notificado la liquidación. La AEAT requiere documentación adicional.
El contribuyente debe presentar ante la AEAT los justificantes. La AEAT verificará
los datos. En caso de discrepancia, la AEAT solicitará aclaraciones...
"""
resultado = expandir_siglas(documento_largo, ExpansionOptions(expand_only_first=True))
# Resultado:
# "La AEAT (Agencia Estatal de Administración Tributaria) ha notificado...
# La AEAT requiere documentación... (resto sin expandir)"
Beneficios:
- Documentos de 100 páginas permanecen legibles
- Reduce el tamaño del documento en un 70-80% cuando hay muchas siglas repetidas
- Perfecto para sentencias judiciales, contratos, informes técnicos
Excluir siglas específicas
resultado = expandir_siglas('AEAT, BOE y CC', ExpansionOptions(exclude=['CC']))
print(resultado)
# Salida: 'AEAT (Agencia Estatal de Administración Tributaria), BOE (Boletín Oficial del Estado) y CC'
Incluir solo siglas específicas
resultado = expandir_siglas('AEAT, BOE, CC, IVA y IRPF', ExpansionOptions(include=['AEAT', 'BOE']))
print(resultado)
# Salida: 'AEAT (Agencia Estatal de Administración Tributaria), BOE (Boletín Oficial del Estado), CC, IVA y IRPF'
Combinar opciones
resultado = expandir_siglas(documento, ExpansionOptions(
format='html',
expand_only_first=True,
exclude=['CC', 'art.'],
preserve_case=True
))
Manejo de duplicados
Problema de duplicados
Algunas siglas tienen múltiples significados posibles. Por ejemplo, "DGT" puede referirse a "Dirección General de Tributos" o "Dirección General de Tráfico". Por defecto, estas siglas no se expanden.
resultado = expandir_siglas('La DGT informa')
print(resultado)
# Salida: 'La DGT informa' (no se expande porque tiene múltiples significados)
Resolución manual de duplicados
resultado = expandir_siglas('La DGT ha emitido una consulta vinculante', ExpansionOptions(
duplicate_resolution={
'DGT': 'Dirección General de Tributos'
}
))
print(resultado)
# Salida: 'La DGT (Dirección General de Tributos) ha emitido una consulta vinculante'
Auto-resolver duplicados
resultado = expandir_siglas('La DGT informa', ExpansionOptions(auto_resolve_duplicates=True))
print(resultado)
# Salida: 'La DGT (Dirección General de Tributos) informa'
# (usa el significado con mayor prioridad)
Consultar duplicados
from legal_expand import buscar_sigla
info = buscar_sigla('DGT')
print(info)
# AcronymSearchResult(acronym='DGT', meanings=['Dirección General de Tributos', 'Dirección General de Tráfico'], has_duplicates=True)
if info.has_duplicates:
print(f"La sigla {info.acronym} tiene {len(info.meanings)} significados posibles")
Funciones auxiliares
Buscar sigla específica
from legal_expand import buscar_sigla
info = buscar_sigla('AEAT')
print(info)
# AcronymSearchResult(acronym='AEAT', meanings=['Agencia Estatal de Administración Tributaria'], has_duplicates=False)
Listar todas las siglas
from legal_expand import listar_siglas
siglas = listar_siglas()
print(f"Total de siglas: {len(siglas)}")
print(f"Primeras 10: {siglas[:10]}")
# Salida: ['AEAT', 'AENA', 'AIE', 'AJD', 'AMI', ...]
Obtener estadísticas
from legal_expand import obtener_estadisticas
stats = obtener_estadisticas()
print(stats)
# DictionaryStats(total_acronyms=646, acronyms_with_duplicates=0, acronyms_with_punctuation=150)
print(f"El diccionario contiene {stats.total_acronyms} siglas")
Uso en frameworks
FastAPI
from fastapi import FastAPI
from pydantic import BaseModel
from legal_expand import expandir_siglas, ExpansionOptions
app = FastAPI()
class TextoRequest(BaseModel):
texto: str
formato: str = 'plain'
@app.post("/expandir")
async def expandir(request: TextoRequest):
resultado = expandir_siglas(
request.texto,
ExpansionOptions(format=request.formato)
)
return {"resultado": resultado}
Flask
from flask import Flask, request, jsonify
from legal_expand import expandir_siglas, ExpansionOptions
app = Flask(__name__)
@app.route('/expandir', methods=['POST'])
def expandir():
data = request.get_json()
resultado = expandir_siglas(
data['texto'],
ExpansionOptions(format=data.get('formato', 'plain'))
)
return jsonify({'resultado': resultado})
Django
# views.py
from django.http import JsonResponse
from django.views.decorators.csrf import csrf_exempt
import json
from legal_expand import expandir_siglas, ExpansionOptions
@csrf_exempt
def expandir_view(request):
if request.method == 'POST':
data = json.loads(request.body)
resultado = expandir_siglas(
data['texto'],
ExpansionOptions(format=data.get('formato', 'plain'))
)
return JsonResponse({'resultado': resultado})
Streamlit
import streamlit as st
from legal_expand import expandir_siglas, ExpansionOptions
st.title("Expansor de Siglas Legales")
texto = st.text_area("Introduce el texto legal:")
formato = st.selectbox("Formato:", ['plain', 'html', 'structured'])
if st.button("Expandir"):
resultado = expandir_siglas(texto, ExpansionOptions(format=formato))
if formato == 'structured':
st.json({
'original': resultado.original_text,
'expandido': resultado.expanded_text,
'siglas': len(resultado.acronyms)
})
else:
st.write(resultado)
Casos de uso completos
Procesamiento de sentencias judiciales
from legal_expand import expandir_siglas, ExpansionOptions
def procesar_sentencia(sentencia: str) -> str:
return expandir_siglas(sentencia, ExpansionOptions(
format='html',
expand_only_first=True,
exclude=['art.', 'núm.'] # Muy comunes, no expandir
))
sentencia = """
Visto el recurso de casación interpuesto por la AEAT contra
la sentencia dictada por la AN el 15 de marzo de 2024, en
relación con la liquidación del IVA correspondiente al ejercicio
2023, y de conformidad con el art. 123 de la LEC...
"""
sentencia_expandida = procesar_sentencia(sentencia)
Generación de glosarios automáticos
from legal_expand import expandir_siglas, ExpansionOptions
def generar_documento_con_glosario(texto: str) -> str:
resultado = expandir_siglas(texto, ExpansionOptions(
format='structured',
expand_only_first=True
))
# Generar glosario único (sin duplicados)
glosario = {}
for sigla in resultado.acronyms:
if sigla.acronym not in glosario:
glosario[sigla.acronym] = sigla.expansion
# Construir documento final
documento_final = resultado.expanded_text
if glosario:
documento_final += '\n\n## Glosario de Siglas\n\n'
for sigla, significado in sorted(glosario.items()):
documento_final += f"- **{sigla}**: {significado}\n"
return documento_final
documento = 'La AEAT gestiona el IVA y el IRPF según normativa del BOE.'
con_glosario = generar_documento_con_glosario(documento)
print(con_glosario)
Uso en backend para LLMs
Una de las aplicaciones más potentes del paquete es pre-procesar textos legales antes de enviarlos a un LLM.
Beneficios de pre-formatear para LLMs
- Mayor precisión: El LLM entiende el contexto completo sin tener que adivinar significados
- Control centralizado: Toda la lógica de expansión está en el backend
- Consistencia: Todos los textos procesados siguen las mismas reglas
FastAPI + OpenAI
from fastapi import FastAPI
from pydantic import BaseModel
from openai import OpenAI
from legal_expand import expandir_siglas, ExpansionOptions
app = FastAPI()
client = OpenAI()
class AnalisisRequest(BaseModel):
texto_legal: str
@app.post("/analizar-legal")
async def analizar_legal(request: AnalisisRequest):
# 1. Expandir siglas en el backend
texto_expandido = expandir_siglas(request.texto_legal, ExpansionOptions(
format='plain',
expand_only_first=True
))
# 2. Enviar al LLM con contexto completo
completion = client.chat.completions.create(
model="gpt-4",
messages=[
{"role": "system", "content": "Eres un asistente legal experto en derecho español."},
{"role": "user", "content": texto_expandido}
]
)
return {
"texto_original": request.texto_legal,
"texto_expandido": texto_expandido,
"analisis_llm": completion.choices[0].message.content
}
AWS Lambda
import json
import boto3
from legal_expand import expandir_siglas, ExpansionOptions
bedrock = boto3.client('bedrock-runtime', region_name='us-east-1')
def lambda_handler(event, context):
body = json.loads(event['body'])
documento = body['documento']
# Expandir siglas
documento_expandido = expandir_siglas(documento, ExpansionOptions(
format='plain',
expand_only_first=True
))
# Usar AWS Bedrock con modelo de tu eleccion
response = bedrock.invoke_model(
modelId='amazon.titan-text-express-v1',
body=json.dumps({
"inputText": f"Analiza este documento legal:\n\n{documento_expandido}",
"textGenerationConfig": {
"maxTokenCount": 4096,
"temperature": 0.7
}
})
)
resultado_modelo = json.loads(response['body'].read())
return {
'statusCode': 200,
'body': json.dumps({
'documento_expandido': documento_expandido,
'analisis': resultado_modelo['results'][0]['outputText']
})
}
Protección de contextos
El paquete incluye detección inteligente de contextos donde las siglas no deben expandirse.
URLs
texto = 'Visita https://aeat.es para más información sobre AEAT'
resultado = expandir_siglas(texto)
print(resultado)
# Salida: 'Visita https://aeat.es para más información sobre AEAT (Agencia Estatal de Administración Tributaria)'
# La URL queda intacta
Direcciones de email
texto = 'Contacta con info@aeat.es o con la AEAT directamente'
resultado = expandir_siglas(texto)
print(resultado)
# Salida: 'Contacta con info@aeat.es o con la AEAT (Agencia...) directamente'
Bloques de código
texto = """
Para usar AEAT en código:
```python
AEAT = require('aeat')
La AEAT es un organismo oficial. """
resultado = expandir_siglas(texto)
El código dentro de ``` no se toca, pero "La AEAT es..." sí se expande
## Extensibilidad
### Crear formatter personalizado
```python
from legal_expand import FormatterFactory, Formatter
from legal_expand.types import MatchInfo
class MarkdownFormatter(Formatter):
def format(self, original_text: str, matches: list[MatchInfo]) -> str:
if not matches:
return original_text
# Ordenar por posición descendente
sorted_matches = sorted(matches, key=lambda m: m.start_pos, reverse=True)
result = original_text
for match in sorted_matches:
acronym = original_text[match.start_pos:match.end_pos]
replacement = f"**{acronym}** ({match.expansion})"
result = result[:match.start_pos] + replacement + result[match.end_pos:]
return result
# Registrar el formatter
FormatterFactory.register_formatter('markdown', MarkdownFormatter())
# Usar el formatter personalizado
resultado = expandir_siglas('La AEAT notifica', ExpansionOptions(format='markdown'))
print(resultado)
# Salida: 'La **AEAT** (Agencia Estatal de Administración Tributaria) notifica'
API completa
expandir_siglas(texto, opciones?)
Función principal que expande siglas en un texto.
Parámetros:
texto(str): Texto a procesaropciones(ExpansionOptions, opcional): Configuración de expansión
Retorna: str | StructuredOutput según el formato especificado
ExpansionOptions
@dataclass
class ExpansionOptions:
format: Literal['plain', 'html', 'structured'] = 'plain'
force_expansion: Optional[bool] = None
preserve_case: bool = True
auto_resolve_duplicates: bool = False
duplicate_resolution: dict[str, str] = field(default_factory=dict)
expand_only_first: bool = False
exclude: list[str] = field(default_factory=list)
include: Optional[list[str]] = None
StructuredOutput
@dataclass
class StructuredOutput:
original_text: str
expanded_text: str
acronyms: list[ExpandedAcronym]
stats: Stats
configurar_globalmente(config)
Configura el comportamiento global del paquete.
@dataclass
class GlobalConfig:
enabled: bool = True
default_options: Optional[ExpansionOptions] = None
obtener_configuracion_global()
Retorna la configuración global actual.
resetear_configuracion()
Restaura la configuración global a valores por defecto.
buscar_sigla(sigla)
Busca información sobre una sigla específica en el diccionario.
Retorna: AcronymSearchResult | None
@dataclass
class AcronymSearchResult:
acronym: str
meanings: list[str]
has_duplicates: bool
listar_siglas()
Retorna lista con todas las siglas disponibles.
Retorna: list[str]
obtener_estadisticas()
Retorna estadísticas del diccionario.
@dataclass
class DictionaryStats:
total_acronyms: int
acronyms_with_duplicates: int
acronyms_with_punctuation: int
Siglas incluidas
El paquete incluye 646 siglas legales españolas, organizadas en las siguientes categorías:
Impuestos y tributos (45 siglas)
AEAT, IVA, IRPF, IS, ISD, ITP, AJD, IVTM, IBI, IAE, ICIO, IEPPF, IGIC, IGTE, II.EE., IIVTNU, IMIVT, IP, IPC, IRNR, etc.
Leyes y normativa (80+ siglas)
CC, CCom, CE, LEC, LECrim, LEF, LES, LG, LGDCU, LGEP, LGP, LGSS, LGT, LH, LHL, LIRPF, LIS, LISOS, LIVA, LJCA, LOCE, LODE, LOFAGE, LOFCA, LOGSE, LOLS, LOPJ, LOTC, LOTCu, LOTJ, LPA, LPACAP, etc.
Organismos e instituciones (60+ siglas)
AENA, AN, AP, BCE, BEI, BOCG, BOE, BOICAC, BOP, CC.AA., CEOE, CES, CGPJ, CNMV, DGCHT, DGRN, DGT, EE.GG., EE.LL., FEADER, FEDER, FEOGA, FFAA, FNMT, FOGASA, FSE, ICAC, IMSERSO, INEM, etc.
Abreviaturas comunes (30+ siglas)
art., apdo., cfr., disp. adic., disp. derog., disp. final, disp. trans., DNI, expte., Excmo., Ilmo., núm., párr., rec., recl., Rgto., Rs., S., Ss., ss., etc.
Tipos de sociedades (15+ siglas)
S.A., S.A.L., S.Coop., S.L., S.R.L., S.A.T., s.en C., SLNE, SCE, AIE, UTE, etc.
Rendimiento
El paquete está optimizado para procesar documentos legales de forma eficiente:
- Tiempo de procesamiento:
- Textos pequeños (100 palabras): menos de 5ms
- Textos medianos (1,000 palabras): menos de 20ms
- Textos grandes (10,000 palabras): menos de 100ms
- Optimizaciones:
- Regex pre-compilada al cargar el módulo
- Diccionario indexado para búsquedas O(1)
- Sin dependencias en runtime
Compatibilidad
- Python: 3.9, 3.10, 3.11, 3.12, 3.13
- Frameworks: FastAPI, Flask, Django, Streamlit, y otros
- Sin dependencias en runtime
Fuentes de las siglas
El diccionario de siglas ha sido compilado de múltiples fuentes oficiales:
Fuentes institucionales
Real Academia Española (RAE) - Libro de Estilo de la Justicia
Apéndice 2: Siglas más usualmente empleadas en textos jurídicos españoles.
Diccionario Panhispánico del Español Jurídico (DPEJ) - RAE
Diccionario especializado con definiciones jurídicas enriquecidas.
Fuentes propias
- Boletín Oficial del Estado (BOE)
- Legislación española vigente
- Documentación de organismos públicos (AEAT, Seguridad Social, etc.)
- Práctica jurídica habitual en España
Proceso de validación
Todas las siglas incluidas han sido:
- Verificadas contra fuentes oficiales
- Normalizadas según criterios de la RAE
- Priorizadas según frecuencia de uso en textos legales
- Depuradas eliminando duplicados y variantes incorrectas
Contribuir
Las contribuciones son bienvenidas. Para contribuir:
- Haz fork del repositorio
- Crea una rama para tu funcionalidad (
git checkout -b feature/nueva-funcionalidad) - Realiza tus cambios y añade tests si es necesario
- Asegúrate de que todos los tests pasan (
pytest) - Haz commit de tus cambios
- Crea un Pull Request
Añadir nuevas siglas
Para añadir nuevas siglas, edita el archivo src/legal_expand/data/dictionary.json siguiendo el formato existente.
Licencia
MIT
Créditos
Desarrollado con el diccionario de 646 siglas legales españolas verificadas de fuentes oficiales (RAE, BOE, DPEJ).
Basado en el paquete npm legal-expand.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file legal_expand-1.0.0.tar.gz.
File metadata
- Download URL: legal_expand-1.0.0.tar.gz
- Upload date:
- Size: 68.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a81a138374ea170d568b36b8973b02a382d243b0ead4cf0ab095ff9361cdb9c
|
|
| MD5 |
367f7d7625df590d5cf907e713713296
|
|
| BLAKE2b-256 |
afb2e1420acd1da34dd406ca144e642e2b26ef9a8fb150d8919b33b941fd6661
|
File details
Details for the file legal_expand-1.0.0-py3-none-any.whl.
File metadata
- Download URL: legal_expand-1.0.0-py3-none-any.whl
- Upload date:
- Size: 64.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0f8b1a5ba00f22caf2836d835a11fc09359c6d13fb547005beb06a1f86626f09
|
|
| MD5 |
34ea59fad3d476f7369aac18f85f8049
|
|
| BLAKE2b-256 |
a436e5fecb54a3ce6ec8f418ab5eaad9a66d119b4f105ca5254b8fa6a13ee6b1
|