前提・実現したいこと
スクレイピングしたデータをDjangoORMを使ってテンプレートに表示さしたいのですが上手く表示さすことができません。コードは下記のようにしてarry = []というリストにスクレイピンしたデータを格納させ、そこからORMでクエリセットさせて取得してる要素をfor文で回して一つ一つ表示させたいのですがスクレイピングした一つ目の要素しかテンプレートには表示されません。
どのようにすれば上手くスクレイピングしたすべてのデータを表示さすことが可能なのでしょうか??
ぜひ、アドバイスいただきたいです。
よろしくお願いします。
該当のソースコード
views.py
import chromedriver_binary from selenium import webdriver from selenium.webdriver.common.keys import Keys from selenium.webdriver.chrome.options import Options from .models import Meibo, Content from django.urls import reverse_lazy from django.views.generic import CreateView options = Options() options.headless = True options.add_argument('--headless') driver = webdriver.Chrome(options=options) driver.get( "動的なwebサイト") class Create(CreateView): template_name = 'index.html' model = Meibo fields = ('name', 'link', 'date') success_url = reverse_lazy('lo') def mou(request): arry = [] selector = '日付の要素' element = driver.find_elements_by_css_selector(selector) element = [a.get_attribute("href") for a in element] date_element = "リンク先の要素" dates = driver.find_elements_by_css_selector(date_element) dates = [b.text for b in dates] # print(dates) i = '名前の要素' items = driver.find_elements_by_css_selector(i) items = [c.text for c in items] for x in items: for y in element: for z in dates: arry.append([x, y, z]) # print(arry)←ここでは[["名前","日付","リンク先"],["名前","日付","リンク先"],["名前","日付","リンク先"]]......と取得できてるのを確認。 for e in arry: b = Meibo.objects.create(name=e[0], link=e[1], date=e[2]) #print(b.name)←ここまではうまくデータが表示できています。 #print(b.link)←ここまではうまくデータが表示できています。 #print(b.date)ここまではうまくデータが表示できています。 param = {'content': b}←ここで要素が一つづつしか取れていないと感じます。下記のindex.htmlで表示さすと一つづつしか取れていません。 return render(request, 'index.html', param)
index.html
<!DOCTYPE html> <body> <table border="2"> <tr> <th scope="col">名前</th> <th scope="col">リンク先</th> <th scope="col">日付</th> <th>id</th> </tr> <tr> <td>{{ context.name }}</td> <td><a href="{{ content.link }}">{{ content.link }}</a></td> <td>{{ content.date }}</td> </tr> </table> </body>
models.py
class Meibo(models.Model): name = models.CharField(verbose_name='名前', max_length=255) link = models.CharField(verbose_name='リンク先', max_length=255, null=True) date = models.CharField(verbose_name='日付', max_length=255, null=True) def __str__(self): return self.name class Content(models.Model): company = models.ForeignKey(Meibo, on_delete=models.CASCADE) good = models.CharField(verbose_name='いいね', max_length=255) def __str__(self): return self.title
admin.pyにはおそらく、うまくスクレイピングしたデータが振り分けて要素が格納されているので、おそらくviews.pyのparamのテンプレートに渡す形式がよくないのとテンプレートでもfor文を使わないといけないのかな?と考えているのですが、、、その方法が分かりません。。
(違うのかもしれません)
補足情報(FW/ツールのバージョンなど)
mac10.15.3
python3.8
あなたの回答
tips
プレビュー