MobileMall BlogMobileMall BlogMobileMall Blog
  • #Explore
  • Business
  • Technology
    • Gaming
    • Headphones
    • Laptops
    • Mobile Accessories
    • Home Networking
    • PCs
    • Printers
    • Smart Watches
    • Speakers
    • Streaming Devices
    • Tablets
    • Wearables
    • Smart Office
  • Security
  • Buying Guides
  • Contribute
Reading: How to Create Manual Sitemaps For Large Custom Websites
Share
Font ResizerAa
MobileMall BlogMobileMall Blog
Font ResizerAa
  • #Explore
  • Business
  • Technology
  • Security
  • Buying Guides
  • Contribute
  • #Explore
  • Business
  • Technology
    • Gaming
    • Headphones
    • Laptops
    • Mobile Accessories
    • Home Networking
    • PCs
    • Printers
    • Smart Watches
    • Speakers
    • Streaming Devices
    • Tablets
    • Wearables
    • Smart Office
  • Security
  • Buying Guides
  • Contribute
2025 © Mobilemall. All Rights Reserved.
Home » Blog » How to Create Manual Sitemaps For Large Custom Websites
DevelopmentSEO

How to Create Manual Sitemaps For Large Custom Websites

Mohammad Ahsan
Last updated: November 11, 2025 9:53 am
Mohammad Ahsan
Share
How to Create Manual Sitemaps For Large Custom Websites
SHARE

Contents

  1. I’ll share three Python scripts:
    1. Script 1:
    2. Script 2
    3. Script 3

I recently received a message on LinkedIn about creating sitemaps for large websites with thousands of pages. Free sitemap generators like xml-sitemaps.com and mysitemapgenerator.com only work for a limited number of URLs, If you are doing SEO for custom websites not using any CMS will can require your technical SEO skills, here you can’t take benefit of SEO plugins that create automatically for you, so you’ll need a different solution for bigger sites custom sites.

I know two ways to create sitemaps for large sites: manual creation using CSV and Notepad, and automated creation using Python. Today, I’ll share the Python method, which requires basic Python knowledge.

I’ll share three Python scripts:

  1. Single File Script: Creates one XML file for a list of URLs (suitable for up to 25,000 URLs).
  2. Category Script: Divides sitemaps into categories (works for even 1 million URLs).
  3. Alphabetical Script: Divides sitemaps into 26 files, one for each letter of the alphabet (also works for 1 million URLs).

You can run this code in Google Colab or In Your Local System by Pycharm!

Script 1:

import pandas as pd
from lxml import etree


df = pd.read_csv('list.csv')  # Assuming the URLs are in the first column

# XML Sitemap structure
urlset = etree.Element("urlset", xmlns="http://www.sitemaps.org/schemas/sitemap/0.9")

for url in df.iloc[:, 0]:  # Loop through the first column containing URLs
    url_element = etree.SubElement(urlset, "url")
    loc = etree.SubElement(url_element, "loc")
    loc.text = url
    changefreq = etree.SubElement(url_element, "changefreq")
    changefreq.text = "weekly"
    priority = etree.SubElement(url_element, "priority")
    priority.text = "1.0"


sitemap = etree.tostring(urlset, pretty_print=True, xml_declaration=True, encoding='UTF-8')

# Save the sitemap
with open("sitemap.xml", "wb") as file:
    file.write(sitemap)

print("Sitemap generated and saved as sitemap.xml")

REQUIRED CSV

List.csv just place the list of urls in column A, (this list will have your list of urls that you want to get to get in the sitemap) now if you wonder where can i get my website list of urls, you need to export it from your database!

Script 2

import csv
import os
from collections import defaultdict
from xml.etree.ElementTree import Element, SubElement, tostring
from xml.dom import minidom

def prettify(elem):
    """Return a pretty-printed XML string for the Element."""
    rough_string = tostring(elem, 'utf-8')
    reparsed = minidom.parseString(rough_string)
    return reparsed.toprettyxml(indent=" ")

def create_sitemap(urls):
    """Create sitemap XML for a list of URLs."""
    urlset = Element('urlset', xmlns='http://www.sitemaps.org/schemas/sitemap/0.9')
    for url in urls:
        url_elem = SubElement(urlset, 'url')
        loc = SubElement(url_elem, 'loc')
        loc.text = url
        changefreq = SubElement(url_elem, 'changefreq')
        changefreq.text = 'daily'
    return prettify(urlset)

def read_urls_from_csv(file_path):
    """Read URLs from a CSV file."""
    with open(file_path, newline='', encoding='utf-8') as csvfile:
        reader = csv.reader(csvfile)
        return [(row[0], row[1]) for row in reader if len(row) >= 2]  # Ensure the row has at least two columns

def main():
    csv_file_path = 'list.csv'  # Path to your CSV file
    url_data = read_urls_from_csv(csv_file_path)

    # Organize URLs by category
    url_dict = defaultdict(list)
    for category, url in url_data:
        url_dict[category].append(url)

    # Create and save sitemaps
    for category, urls in url_dict.items():
        sitemap = create_sitemap(urls)
        file_name = f'{category}.xml'
        with open(file_name, 'w', encoding='utf-8') as file:
            file.write(sitemap)
        print(f'Sitemap for {category} saved as {file_name}')

if __name__ == '__main__':
    main()

REQUIRED CSV

List.csv just place the Title/Value of categores in Column A & urls next to respective Category column B, (you need to export database, and in csv you can apply filter of two columns category and list of slugs/urls of your website)!

Script 3

import csv
import os
from collections import defaultdict
from xml.etree.ElementTree import Element, SubElement, tostring
from xml.dom import minidom

def prettify(elem):
    """Return a pretty-printed XML string for the Element."""
    rough_string = tostring(elem, 'utf-8')
    reparsed = minidom.parseString(rough_string)
    return reparsed.toprettyxml(indent=" ")

def create_sitemap(urls):
    """Create sitemap XML for a list of URLs."""
    urlset = Element('urlset', xmlns='http://www.sitemaps.org/schemas/sitemap/0.9')
    for url in urls:
        url_elem = SubElement(urlset, 'url')
        loc = SubElement(url_elem, 'loc')
        loc.text = url
        changefreq = SubElement(url_elem, 'changefreq')
        changefreq.text = 'daily'
    return prettify(urlset)

def read_urls_from_csv(file_path):
    """Read URLs from a CSV file."""
    with open(file_path, newline='', encoding='utf-8') as csvfile:
        reader = csv.reader(csvfile)
        return [row[0] for row in reader if row]  # Ensure the row is not empty

def main():
    csv_file_path = 'list.csv'  # Path to your CSV file
    urls = read_urls_from_csv(csv_file_path)

    # Organize URLs by first letter after domain
    url_dict = defaultdict(list)
    for url in urls:
        parts = url.split('/')
        if parts[-1]:  # Ensure the last part is not empty
            letter = parts[-1][0].lower()
        else:
            letter = parts[-2][0].lower() if len(parts) > 1 else 'other'
        url_dict[letter].append(url)

    # Create and save sitemaps
    for letter, urls in url_dict.items():
        sitemap = create_sitemap(urls)
        file_name = f'stores-{letter}.xml'  # Corrected file name with underscore
        with open(file_name, 'w', encoding='utf-8') as file:
            file.write(sitemap)
        print(f'Sitemap for {letter} saved as {file_name}')

if __name__ == '__main__':
    main()

REQUIRED CSV

List.csv just place the urls Column A, script will use it’s own logic to create sitemaps by aplahabet order(just export list of urls from your database).

What Is Shared Hosting? Explained in Detail
Essential Skills and Mindset for Modern Developers Digital Era
Word Press Vs BlogSpot | Which is Ideal for Beginners?
Leveraging ChatGPT For Your SEO
Top 5 SEO Tools To Analyze And Rank Your Website In 2021

Sign Up For Daily Newsletter

Be keep up! Get the latest breaking news delivered straight to your inbox.
[mc4wp_form]
By signing up, you agree to our Terms of Use and acknowledge the data practices in our Privacy Policy. You may unsubscribe at any time.
Share This Article
Facebook Copy Link Print
Share
ByMohammad Ahsan
Follow:
is a creative writer & a BBA Student from Karachi Pakistan. He is Co-Admin at Mobilemall.pk. Mostly share ideas about Mobile Phones, Technology, SEO, SEM, PPC, etc.
Previous Article Apple Intelligence Features To Use Apple Intelligence Features You’ll Need To Join The Waitlist
Next Article Windows Hosting for Security-Conscious Businesses: Best Practices Windows Hosting for Security-Conscious Businesses: Best Practices

Latest News

Google Suspended a Railway's Account and an Entire Platform Went Dark
Google Suspended a Railway’s Account and an Entire Platform Went Dark – What It Teaches Us About Cloud Lock-in
Cloud Storage
Android 17 QPR1 Beta 4 Pixel update
Google rolls out Android 17 QPR1 Beta 4 to Pixel phones, but Pixel 6 and 6 Pro miss out
Google
YouTube in-app messaging
YouTube Brings Back In-App Messaging Six Years After Killing It
Social Media
agent deposit networks
How Peer-to-Peer Agent Deposit Systems Actually Work Behind the Screen
Tech Lifestyle
Apple Intelligence 12GB RAM Requirement
Apple’s Most Advanced On-Device AI Features Won’t Work on Every iPhone
Apple News
Apple's Foldable Iphone
iPhone Ultra Is Coming: The iOS 27 Code Makes That Pretty Clear
Apple Data Science News
cute-phone-cases
Cute Phone Cases That Stay Stylish and Durable Every Day (2026 Guide)
Accessories
samsung-galaxy-z-fold8-ultra
Samsung Z Fold8 Ultra Reportedly Jumps to 5,000mAh Battery — No Extra Weight
News Samsung

You Might also Like

SEO Plan Needs to Enhance UX
SEO

6 Useful Strategies Your SEO Plan Needs to Enhance UX

Mohammad Ahsan
Mohammad Ahsan
9 Min Read
Transforming Mobile App Development with AI Software Testing Tools
Development

Transforming Mobile App Development with AI Software Testing Tools

Anastasiia (Developer)
Anastasiia (Developer)
4 Min Read
Ice Universe Oppo Processor
DevelopmentTechnology

OPPO Develops Its Own Processor for Future Smartphones, Launching in 2024

Adam Lyttle (Developer)
Adam Lyttle (Developer)
2 Min Read

About us

Mobilemall.co blog is an informative and engaging platform that offers readers the latest news and insights on mobile phones and accessories. The blog covers a wide range of topics, including product reviews, industry trends, and tips on how to get the most out of your mobile device.

Contact Us:
[email protected]

Categories Link

  • Business
  • Mobile
  • Technology
  • Gaming
  • Phone Review
  • Android

Must Read

Global App Revenue Report
Global App Revenue Report  — Five Brands That Prove Where the Money Actually Went
Business
crypto-casinos
Crypto Casinos Pulled In $81 Billion Last Year, and That’s Five Times What They Made in 2022
Business Entertainment

Quick Links

  • Privacy Policy
  • Tech Write For Us
  • Contact Us
  • Facebook
  • Instagram
  • YouTube
  • LinkedIn
2026 © Mobilemall. All Rights Reserved.
Go to mobile version
Welcome Back!

Sign in to your account

Username or Email Address
Password

Lost your password?

Not a member? Sign Up