5

Google<image>は XML サイトマップ ( http://support.google.com/webmasters/bin/answer.py?hl=ja&answer=178636 ) のタグを認識し、サイトマップに画像属性を含めたいと考えています。

したがって、cover_image を取得して xml ファイルにロードするには、次のようなものが必要です。

for article in articles:
        print article.cover_image

タグにもarticle.titleロードする必要があります。<image:title>

例として Stack Overflow を Google で検索しましたが、驚くべきことに何も見つからなかったので、助けていただければ幸いです。

これまでの私のファイル:

## sitemaps.py ##
from django.contrib.sitemaps import Sitemap
from myproject.article.models import Article

class ArticleSitemap(Sitemap):
    priority = 1.0

    def items(self):
        return  Article.objects.order_by('-id').order_by('-pub_date')

    def lastmod(self, obj):
        return obj.pub_date

## urls.py ##
from myproject.sitemaps import ArticleSitemap

sitemaps = {
    "article": ArticleSitemap
}
urlpatterns += patterns ('',
    (r'^sitemap.xml$', 'django.contrib.sitemaps.views.sitemap', {'sitemaps': sitemaps})
4

3 に答える 3

9

それはによって行うことができます

  1. 継承したクラスで get_urls メソッドを再定義する (画像情報を追加する)
  2. 既定のテンプレートを、画像情報のレンダリングに必要なテンプレートに変更します

コードは次のとおりです。

  1. これらのメソッドをクラスに追加します。これらのメソッドは、django のサイトマップ フレームワークで定義されているものとほとんど同じですが、テンプレートでレンダリングする必要があるデータを準備する方法が異なります。

    class MySItemapClass(Sitemap):
      def item():
         .........        
    
      def __get(self, name, obj, default=None):
        try:
          attr = getattr(self, name)
        except AttributeError:
          return default
        if callable(attr):
          return attr(obj)
        return attr
    
      def get_urls(self, page=1, site=None, protocol=None):
        # Determine protocol
        if self.protocol is not None:
          protocol = self.protocol
        if protocol is None:
          protocol = 'http'
    
        # Determine domain
        if site is None:
          if Site._meta.installed:
              try:
                  site = Site.objects.get_current()
              except Site.DoesNotExist:
                  pass
          if site is None:
              raise ImproperlyConfigured("To use sitemaps, either enable the sites framework or pass a Site/RequestSite object in your view.")
        domain = site.domain
    
        urls = []
        for item in self.paginator.page(page).object_list:
          loc = "%s://%s%s" % (protocol, domain, self.__get('location', item))
          priority = self.__get('priority', item, None)
          url_info = {
              'item':       item,
              'location':   loc,
              'lastmod':    self.__get('lastmod', item, None),
              'changefreq': self.__get('changefreq', item, None),
              'priority':   str(priority is not None and priority or ''),
              'images'   :   get_image(protocol, domain,item), # changed here
          }
          urls.append(url_info)
        return urls
    

自由に定義get_image methodしてください

  1. カスタム テンプレートを定義します。私はこのように見えます-名前空間( "urlset")の定義の変更に注意してください

    <?xml version="1.0" encoding="UTF-8"?>
    <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"
      xmlns:image="http://www.google.com/schemas/sitemap-image/1.1">
    {% spaceless %}
    {% for url in urlset %}
      <url>
        <loc>{{ url.location }}</loc>
        {% if url.images %}
            {% for image in url.images %}
                <image:image>
                    <image:loc>{{image}}</image:loc>
                </image:image>
            {% endfor %}
        {% endif %}
        {% if url.lastmod %}<lastmod>{{ url.lastmod|date:"Y-m-d" }}</lastmod>{% endif %}
        {% if url.changefreq %}<changefreq>{{ url.changefreq }}</changefreq>{% endif %}
        {% if url.priority %}<priority>{{ url.priority }}</priority>{% endif %}
       </url>
    {% endfor %}
    {% endspaceless %}
    </urlset>
    
  2. デフォルトのテンプレートではなく、新しいテンプレートを使用するようにオーバーライドします

    url(r'^sitemap-(?P<section>.+)\.xml$', 'django.contrib.sitemaps.views.sitemap', {'sitemaps': sitemaps,'template_name': 'seo/sitemap.xml'}),
    
于 2012-11-20T11:33:28.330 に答える
0

テンプレートをレンダリングする前にいくつかの画像を追加して、それらを templateに表示できます。別途申請したほうがいいと思います(継承django.contrib.sitemaps)。

于 2012-04-29T05:45:35.117 に答える