質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

0回答

847閲覧

Mac用アプリのパッケージ内のプログラムだと正常に値を取得できるのに、.appアプリを起動すると値が取得できない

MasterUdemy

総合スコア0

Tkinter

Tkinterは、GUIツールキットである“Tk”をPythonから利用できるようにした標準ライブラリである。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/01/22 01:55

編集2021/01/22 03:42

前提・実現したいこと

pythonで、tkinterでキーワードを入力するインターフェイスを作成して(
getut_data.py)、別ファイル(scrape_u_t.py)で入力されたキーワードを元に、Google検索結果からURLとタイトルを抜き出してデスクトップにCSVを保存するプログラムを作成しました。

virtualenvでpython環境を構築した後、必要な外部ライブラリとpy2appをインストールして、setup.pyをつくってpy2appでMac用アプリを作りました

Pycharmやターミナルから実行すると、問題なくCSVを書き出すことができたので、py2appでMac用アプリを作ったところ、作成されるappが拡張子のアプリをダブルクリックで起動したときには、titileとURLの項目だけ記述されたCSVが作成されました。

アプリのパッケージを開き、MacOSの中にあるプログラムをターミナルで起動してみると、問題なくデータが抽出されて、保存されたCSVには、きちんとデータが保存されています。

ネットでも調べてみたのですが、GUIは環境変数のPATHが通っていないという記事をみつけたものの、関係があるのかどうかもわからず、そのやり方もわからなかったので、藁をも掴む思いで質問しました。

解決の糸口になるようなアドバイスをお願いします。

該当のソースコード


getut_data.py

python

1import tkinter as tk 2import scrape_t_u 3 4class Application(tk.Frame): 5 def __init__(self, master=None): 6 super().__init__(master) 7 self.master.geometry() 8 self.master.title('Get URL and TITLE') 9 10 self.entry = tk.Entry(self.master, width=40) 11 12 self.menu_bar = tk.Menu(self.master) 13 self.master.config(menu=self.menu_bar) 14 15 self.create_widgets() 16 17 def clear_all(self): 18 self.entry.delete(0, tk.END) 19 20 def search(self): 21 keywords = self.entry.get() 22 scrape_t_u.main(keywords) 23 24 def create_widgets(self): 25 file_menu = tk.Menu(self.menu_bar) 26 file_menu.add_command(label='Exit', command=self.master.quit) 27 self.menu_bar.add_cascade(label='File', menu=file_menu) 28 self.entry.grid(row=1, column=1, columnspan=6, pady=10, padx=10) 29 self.entry.focus_set() 30 31 tk.Button(self.master, text='Clear', width=4, 32 command=self.clear_all).grid(row=2, column=5) 33 34 tk.Button(self.master, text='抽出', width=4, 35 command=self.search).grid(row=2, column=6, pady=10) 36 37root = tk.Tk() 38app = Application(master=root) 39app.mainloop()

scrape_u_t.py

import csv import os import re import urllib.parse from bs4 import BeautifulSoup import requests DESKTOP_PATH = os.getenv('HOME') + '/Desktop/url_title.csv' def main(keywords): r = requests.get('https://www.google.co.jp/search?hl=jp&gl=JP&num=10&q=' + keywords) html_soup = BeautifulSoup(r.content, 'html.parser') url_results = [] for t in html_soup.select('.kCrYT > a'): u_result = re.sub(r'/url?q=|&sa.*', '', t.get('href')) url_results.append(urllib.parse.unquote(u_result)) title_results = [] for i in url_results: try: search = requests.get(i) search_soup = BeautifulSoup(search.content, 'html.parser') titles = search_soup.find('title') title_results.append(titles.text) except: print('取得できませんでした。') with open(DESKTOP_PATH, 'w') as csv_file: fieldnames = ['TITLE', 'URL'] writer = csv.DictWriter(csv_file, fieldnames=fieldnames) writer.writeheader() for t, u in zip(title_results, url_results): writer.writerow({'TITLE': t, 'URL': u}) if __name__ == '= '__main__': main()

setup.py

from setuptools import setup APP = ['getut_data.py'] DATA_FILES = ['scrape_t_u.py'] OPTIONS = {} setup( app=APP, data_files=DATA_FILES, options={'py2app': OPTIONS}, setup_requires=['py2app'], )

試したこと

virtualenvで環境構築し、外部ライブラリのpy2appとrequesteとbeautifulsoup4をpipインストールして、py2appでsetup.pyを実行して作成しました。

補足情報

Macos 11.1
MacBook pro 2018 13inch
Pycharm
python3.7

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問