{"id":26309,"date":"2026-05-22T16:39:15","date_gmt":"2026-05-22T07:39:15","guid":{"rendered":"http:\/\/www.tyosuke20xx.com\/blog\/?p=26309"},"modified":"2026-05-22T16:39:17","modified_gmt":"2026-05-22T07:39:17","slug":"python-ai%e3%82%a8%e3%83%bc%e3%82%b8%e3%82%a7%e3%83%b3%e3%83%88","status":"publish","type":"post","link":"http:\/\/www.tyosuke20xx.com\/blog\/?p=26309","title":{"rendered":"python AI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8"},"content":{"rendered":"\n<p class=\"wp-block-paragraph\"># ai_agent_full.py<br># Python\u3060\u3051\u3067\u52d5\u304f\u7c21\u6613AI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8<br># \u6a5f\u80fd:<br># &#8211; \u4f1a\u8a71<br># &#8211; TODO\u7ba1\u7406<br># &#8211; \u30e1\u30e2\u4fdd\u5b58<br># &#8211; \u8a18\u61b6<br># &#8211; \u8a08\u7b97<br># &#8211; \u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58<br># &#8211; \u30b3\u30de\u30f3\u30c9\u5b9f\u884c\u30e1\u30cb\u30e5\u30fc<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">import json<br>import os<br>import datetime<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">DATA_FILE = &#8220;agent_data.json&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">class AIAgent:<br>def __init__(self):<br>self.data = {<br>&#8220;memory&#8221;: [],<br>&#8220;todos&#8221;: [],<br>&#8220;notes&#8221;: []<br>}<br>self.load_data()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def load_data(self):<br>if os.path.exists(DATA_FILE):<br>try:<br>with open(DATA_FILE, &#8220;r&#8221;, encoding=&#8221;utf-8&#8243;) as f:<br>self.data = json.load(f)<br>except:<br>print(&#8220;\u30c7\u30fc\u30bf\u8aad\u307f\u8fbc\u307f\u306b\u5931\u6557\u3057\u307e\u3057\u305f\u3002\u65b0\u898f\u30c7\u30fc\u30bf\u3067\u958b\u59cb\u3057\u307e\u3059\u3002&#8221;)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def save_data(self):<br>with open(DATA_FILE, &#8220;w&#8221;, encoding=&#8221;utf-8&#8243;) as f:<br>json.dump(self.data, f, ensure_ascii=False, indent=2)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def add_memory(self, text):<br>self.data[&#8220;memory&#8221;].append({<br>&#8220;text&#8221;: text,<br>&#8220;date&#8221;: str(datetime.datetime.now())<br>})<br>self.save_data()<br>return &#8220;\u8a18\u61b6\u3057\u307e\u3057\u305f\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def show_memory(self):<br>if not self.data[&#8220;memory&#8221;]:<br>return &#8220;\u8a18\u61b6\u306f\u307e\u3060\u3042\u308a\u307e\u305b\u3093\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">result = &#8220;=== \u8a18\u61b6\u4e00\u89a7 ===\\n&#8221;<br>for i, item in enumerate(self.data[&#8220;memory&#8221;], 1):<br>result += f&#8221;{i}. {item[&#8216;text&#8217;]} ({item[&#8216;date&#8217;]})\\n&#8221;<br>return result<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def add_todo(self, task):<br>self.data[&#8220;todos&#8221;].append({<br>&#8220;task&#8221;: task,<br>&#8220;done&#8221;: False,<br>&#8220;date&#8221;: str(datetime.datetime.now())<br>})<br>self.save_data()<br>return f&#8221;TODO\u3092\u8ffd\u52a0\u3057\u307e\u3057\u305f: {task}&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def show_todos(self):<br>if not self.data[&#8220;todos&#8221;]:<br>return &#8220;TODO\u306f\u3042\u308a\u307e\u305b\u3093\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">result = &#8220;=== TODO\u4e00\u89a7 ===\\n&#8221;<br>for i, todo in enumerate(self.data[&#8220;todos&#8221;], 1):<br>mark = &#8220;\u5b8c\u4e86&#8221; if todo[&#8220;done&#8221;] else &#8220;\u672a\u5b8c\u4e86&#8221;<br>result += f&#8221;{i}. [{mark}] {todo[&#8216;task&#8217;]}\\n&#8221;<br>return result<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def done_todo(self, number):<br>try:<br>index = int(number) &#8211; 1<br>self.data[&#8220;todos&#8221;][index][&#8220;done&#8221;] = True<br>self.save_data()<br>return &#8220;TODO\u3092\u5b8c\u4e86\u306b\u3057\u307e\u3057\u305f\u3002&#8221;<br>except:<br>return &#8220;\u756a\u53f7\u304c\u6b63\u3057\u304f\u3042\u308a\u307e\u305b\u3093\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def delete_todo(self, number):<br>try:<br>index = int(number) &#8211; 1<br>removed = self.data[&#8220;todos&#8221;].pop(index)<br>self.save_data()<br>return f&#8221;TODO\u3092\u524a\u9664\u3057\u307e\u3057\u305f: {removed[&#8216;task&#8217;]}&#8221;<br>except:<br>return &#8220;\u756a\u53f7\u304c\u6b63\u3057\u304f\u3042\u308a\u307e\u305b\u3093\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def add_note(self, text):<br>self.data[&#8220;notes&#8221;].append({<br>&#8220;text&#8221;: text,<br>&#8220;date&#8221;: str(datetime.datetime.now())<br>})<br>self.save_data()<br>return &#8220;\u30e1\u30e2\u3092\u4fdd\u5b58\u3057\u307e\u3057\u305f\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def show_notes(self):<br>if not self.data[&#8220;notes&#8221;]:<br>return &#8220;\u30e1\u30e2\u306f\u3042\u308a\u307e\u305b\u3093\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">result = &#8220;=== \u30e1\u30e2\u4e00\u89a7 ===\\n&#8221;<br>for i, note in enumerate(self.data[&#8220;notes&#8221;], 1):<br>result += f&#8221;{i}. {note[&#8216;text&#8217;]} ({note[&#8216;date&#8217;]})\\n&#8221;<br>return result<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def calculate(self, expression):<br>try:<br>allowed = &#8220;0123456789+-*\/(). &#8220;<br>if not all(c in allowed for c in expression):<br>return &#8220;\u4f7f\u3048\u308b\u306e\u306f\u6570\u5b57\u3068 + &#8211; * \/ \u3060\u3051\u3067\u3059\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">answer = eval(expression)<br>return f&#8221;\u8a08\u7b97\u7d50\u679c: {answer}&#8221;<br>except:<br>return &#8220;\u8a08\u7b97\u3067\u304d\u307e\u305b\u3093\u3067\u3057\u305f\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def save_text_file(self, filename, text):<br>try:<br>with open(filename, &#8220;w&#8221;, encoding=&#8221;utf-8&#8243;) as f:<br>f.write(text)<br>return f&#8221;{filename} \u306b\u4fdd\u5b58\u3057\u307e\u3057\u305f\u3002&#8221;<br>except:<br>return &#8220;\u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58\u306b\u5931\u6557\u3057\u307e\u3057\u305f\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def chat(self, text):<br>if &#8220;\u3053\u3093\u306b\u3061\u306f&#8221; in text:<br>return &#8220;\u3053\u3093\u306b\u3061\u306f\u3002\u4eca\u65e5\u306f\u4f55\u3092\u4f5c\u308a\u307e\u3059\u304b\uff1f&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if &#8220;\u75b2\u308c\u305f&#8221; in text:<br>return &#8220;\u5c11\u3057\u4f11\u307f\u307e\u3057\u3087\u3046\u3002\u7121\u7406\u305b\u305a\u30015\u5206\u3060\u3051\u3067\u3082\u4f11\u61a9\u3059\u308b\u3068\u3044\u3044\u3067\u3059\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if &#8220;Python&#8221; in text or &#8220;python&#8221; in text:<br>return &#8220;Python\u306a\u3089\u3001AI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u3001TODO\u30a2\u30d7\u30ea\u3001Web\u30a2\u30d7\u30ea\u3001\u81ea\u52d5\u5316\u30c4\u30fc\u30eb\u304c\u4f5c\u308c\u307e\u3059\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if &#8220;\u30b2\u30fc\u30e0&#8221; in text:<br>return &#8220;\u30b2\u30fc\u30e0\u958b\u767a\u306a\u3089\u3001\u307e\u305a\u306f\u30ad\u30e3\u30e9\u30af\u30bf\u30fc\u79fb\u52d5\u30fbHP\u30fb\u653b\u6483\u30fb\u6575AI\u304b\u3089\u4f5c\u308b\u306e\u304c\u3044\u3044\u3067\u3059\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">return &#8220;\u306a\u308b\u307b\u3069\u3002\u7d9a\u3051\u3066\u304f\u3060\u3055\u3044\u3002\u5fc5\u8981\u306a\u3089TODO\u3084\u30e1\u30e2\u306b\u4fdd\u5b58\u3067\u304d\u307e\u3059\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def help(self):<br>return &#8220;&#8221;&#8221;<br>=== \u30b3\u30de\u30f3\u30c9\u4e00\u89a7 ===<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u4f1a\u8a71:<br>\u305d\u306e\u307e\u307e\u6587\u7ae0\u3092\u5165\u529b<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u8a18\u61b6:<br>\u8a18\u61b6 \u5185\u5bb9<br>\u8a18\u61b6\u4e00\u89a7<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">TODO:<br>TODO \u5185\u5bb9<br>TODO\u4e00\u89a7<br>\u5b8c\u4e86 \u756a\u53f7<br>\u524a\u9664 \u756a\u53f7<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u30e1\u30e2:<br>\u30e1\u30e2 \u5185\u5bb9<br>\u30e1\u30e2\u4e00\u89a7<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u8a08\u7b97:<br>\u8a08\u7b97 1+2*3<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u30d5\u30a1\u30a4\u30eb\u4fdd\u5b58:<br>\u4fdd\u5b58 \u30d5\u30a1\u30a4\u30eb\u540d \u5185\u5bb9<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u305d\u306e\u4ed6:<br>\u30d8\u30eb\u30d7<br>\u7d42\u4e86<br>&#8220;&#8221;&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def run_command(self, command):<br>command = command.strip()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command == &#8220;&#8221;:<br>return &#8220;\u4f55\u304b\u5165\u529b\u3057\u3066\u304f\u3060\u3055\u3044\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command == &#8220;\u30d8\u30eb\u30d7&#8221;:<br>return self.help()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command == &#8220;\u7d42\u4e86&#8221;:<br>return &#8220;\u7d42\u4e86\u3057\u307e\u3059\u3002&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command.startswith(&#8220;\u8a18\u61b6 &#8220;):<br>text = command.replace(&#8220;\u8a18\u61b6 &#8220;, &#8220;&#8221;, 1)<br>return self.add_memory(text)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command == &#8220;\u8a18\u61b6\u4e00\u89a7&#8221;:<br>return self.show_memory()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command.startswith(&#8220;TODO &#8220;):<br>task = command.replace(&#8220;TODO &#8220;, &#8220;&#8221;, 1)<br>return self.add_todo(task)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command == &#8220;TODO\u4e00\u89a7&#8221;:<br>return self.show_todos()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command.startswith(&#8220;\u5b8c\u4e86 &#8220;):<br>number = command.replace(&#8220;\u5b8c\u4e86 &#8220;, &#8220;&#8221;, 1)<br>return self.done_todo(number)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command.startswith(&#8220;\u524a\u9664 &#8220;):<br>number = command.replace(&#8220;\u524a\u9664 &#8220;, &#8220;&#8221;, 1)<br>return self.delete_todo(number)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command.startswith(&#8220;\u30e1\u30e2 &#8220;):<br>text = command.replace(&#8220;\u30e1\u30e2 &#8220;, &#8220;&#8221;, 1)<br>return self.add_note(text)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command == &#8220;\u30e1\u30e2\u4e00\u89a7&#8221;:<br>return self.show_notes()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command.startswith(&#8220;\u8a08\u7b97 &#8220;):<br>expr = command.replace(&#8220;\u8a08\u7b97 &#8220;, &#8220;&#8221;, 1)<br>return self.calculate(expr)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if command.startswith(&#8220;\u4fdd\u5b58 &#8220;):<br>try:<br>parts = command.split(&#8221; &#8220;, 2)<br>filename = parts[1]<br>text = parts[2]<br>return self.save_text_file(filename, text)<br>except:<br>return &#8220;\u4f7f\u3044\u65b9: \u4fdd\u5b58 \u30d5\u30a1\u30a4\u30eb\u540d \u5185\u5bb9&#8221;<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">return self.chat(command)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">def main():<br>agent = AIAgent()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">print(&#8220;================================&#8221;)<br>print(&#8221; AI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8 \u8d77\u52d5&#8221;)<br>print(&#8220;================================&#8221;)<br>print(&#8220;\u30d8\u30eb\u30d7 \u3068\u5165\u529b\u3059\u308b\u3068\u30b3\u30de\u30f3\u30c9\u4e00\u89a7\u3092\u8868\u793a&#8221;)<br>print(&#8220;\u7d42\u4e86 \u3068\u5165\u529b\u3059\u308b\u3068\u7d42\u4e86&#8221;)<br>print()<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">while True:<br>user_input = input(&#8220;\u3042\u306a\u305f: &#8220;)<br>response = agent.run_command(user_input)<br>print(&#8220;AI:&#8221;, response)<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if user_input.strip() == &#8220;\u7d42\u4e86&#8221;:<br>break<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">if __name__ == &#8220;__main__&#8221;:<br>main()<\/p>\n","protected":false},"excerpt":{"rendered":"<p># ai_agent_full.py# Python\u3060\u3051\u3067\u52d5\u304f\u7c21\u6613AI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8# \u6a5f\u80fd:# &#8211; \u4f1a\u8a71# &#8211; TODO\u7ba1\u7406# &#8211; \u30e1\u30e2\u4fdd\u5b58# &#8211; \u8a18\u61b6# &#8211;  &hellip; <a href=\"http:\/\/www.tyosuke20xx.com\/blog\/?p=26309\" class=\"more-link\"><span class=\"screen-reader-text\">&#8220;python AI\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8&#8221; \u306e<\/span>\u7d9a\u304d\u3092\u8aad\u3080<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"_uf_show_specific_survey":0,"_uf_disable_surveys":false,"footnotes":""},"categories":[55,65],"tags":[],"class_list":["post-26309","post","type-post","status-publish","format-standard","hentry","category-ai","category-python"],"aioseo_notices":[],"jetpack_featured_media_url":"","_links":{"self":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26309","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=26309"}],"version-history":[{"count":1,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26309\/revisions"}],"predecessor-version":[{"id":26311,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=\/wp\/v2\/posts\/26309\/revisions\/26311"}],"wp:attachment":[{"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=26309"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=26309"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.tyosuke20xx.com\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=26309"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}