Skip to main content

JSL Django Sitemap is a Django utility which iterates over all the url patterns in your main Django project and creates a ready to use sitemap. The sitemap.xml is useful in crawlers such as Google, Bing, Yahoo. We hope you like our app! Leave a star on our GitHub repository. Thanks!

Project description

JSL Django Sitemap

Upload Python Package

A sitemap is an XML file on your website that tells search-engine crawlers or indexers how frequently your pages change and how “important” certain pages are in relation to other pages on your site. This information helps search engines index your site.

This Django sitemap framework library automates the creation of this XML file by letting you express this information in Python code. You have the ability to chnge and mention settings in your Django project's settings.py file. It is very convinent and easy to use library which detects the changes in your Django url configuration and reloads the new configuration making absolutely no manual interventions for your sitemap.

JSL Django Sitemap is a sitemap.xml creator for Django projects which iterates over all the url patterns in your main Django project and creates a ready to use sitemap. The sitemap.xml is useful in crawlers such as Google, Bing, Yahoo. We hope you like our app! Leave a star on our GitHub repository. Thanks!

Our Home page JSoftwareLabs.com

Installation

You can install the JSL Django Sitemap from PyPI:

pip install jsl-django-sitemap

Example Usage

Add necessary imports

from jsl_django_sitemap.views import sitemaps
from django.contrib.sitemaps.views import sitemap
from django.urls import path

In your main django project urls.py file add below in urlpatterns

path('sitemap.xml', sitemap, {'sitemaps': sitemaps},
name='django.contrib.sitemaps.views.sitemap'),

In your main settings.py file add below

JSL_DJANGO_SITEMAP_SETTINGS = {
	"ENABLE": True,
	"FETCH_URL_FROM": "pattern",
	"INCLUDE_APPS": ("ALL",),
	"IGNORE_URL_PATTERNS": (".*/api/v1.*", )
}

add django built in sitemap in the INSTALLED_APPS

INSTALLED_APPS = [
	# ...
	'django.contrib.sitemaps',
]

NOTE:

  1. "ALL" means to include all the urls
  2. If you want specific apps to be included in sitemap use below. Provide comma separated tuple containing your app name
  3. "INCLUDE_APPS": ("myapp1","myapp2")
  4. FETCH_URL_FROM: should be one value from the list ["name", "pattern"]
  5. default for FETCH_URL_FROM is "pattern"
  6. By default, if pattern is provided then "^" prefix and "$" suffix in urlpattern is removed.
  7. "IGNORE_URL_PATTERNS": ("./api/v1.", ) This flag is used to ignore certain urls matching the provided tuple of patterns which are regex compatible NOTE: The sitemap application doesn't install any database tables. The only reason it needs to go into INSTALLED_APPS is so that the Loader() template loader can find the default templates.

View generated sitemap:

Start the development server and visit http://127.0.0.1:8000/sitemap.xml


Current Releases

1.2.4

How to build and distribute using sdist setup.py and twine

python3 -m pip install --upgrade twine
python setup.py sdist
twine upload dist/*

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jsl_django_sitemap-1.2.4.tar.gz (6.2 kB view hashes)

Uploaded Source

Built Distribution

jsl_django_sitemap-1.2.4-py3-none-any.whl (7.0 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page