{"id":3545,"date":"2025-06-28T13:06:30","date_gmt":"2025-06-28T05:06:30","guid":{"rendered":"http:\/\/viplao.com\/?p=3545"},"modified":"2025-06-28T13:40:04","modified_gmt":"2025-06-28T05:40:04","slug":"%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90","status":"publish","type":"post","link":"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/","title":{"rendered":"\u3010Python10\u5e74\u7ecf\u9a8c\u603b\u7ed3\u3011\u7b2c\u516d\u8bfe \u7535\u5546\u5e73\u53f0\u9500\u552e\u6570\u636e\u5206\u6790\u5b9e\u8df5 \u2013 \u5206\u6790\u7ed3\u679c\uff08Analysis Insights\uff09"},"content":{"rendered":"\n<p>\u5de5\u4f5c\u5e38\u7528\u7684\u5206\u6790\u7ed3\u679c\u6848\u4f8b\uff1a<\/p>\n\n\n\n<p>\u627e\u51fa\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1<br>\u5206\u6790\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02<br>\u8bc6\u522b\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RFM\u6a21\u578b\uff09<br>\u5206\u6790\u4fc3\u9500\u6d3b\u52a8\u7684\u62c9\u52a8\u6548\u679c<br>\u5206\u6790\u65b0\u54c1\u4e0a\u5e02\u5bf9\u8001\u54c1\u7684\u51b2\u51fb<br>\u5206\u6790\u9000\u8d27\u7387\u4e0e\u5546\u54c1\u7c7b\u522b\u7684\u5173\u7cfb<br>\u5206\u6790\u7528\u6237\u590d\u8d2d\u8def\u5f84<br>\u5206\u6790\u8282\u5047\u65e5\u524d\u540e\u9500\u552e\u6ce2\u52a8<br>\u5206\u6790\u6d41\u91cf\u4e0e\u8f6c\u5316\u7387\u4e4b\u95f4\u7684\u5173\u7cfb<br>\u5206\u6790\u4e0d\u540c\u5e73\u53f0\u6e20\u9053\u7684\u7528\u6237\u753b\u50cf\u5dee\u5f02<\/p>\n\n\n\n<p><\/p>\n\n\n\n<p>\u6211\u4eec\u5c06\u5c55\u793a\u5982\u4f55\u8fdb\u884c\u8fd9\u4e9b\u5e38\u89c1\u7684\u5206\u6790\u4efb\u52a1\u3002\u4e3a\u4e86\u6f14\u793a\u8fd9\u4e9b\u65b9\u6cd5\uff0c\u6211\u4eec\u9700\u8981\u4f7f\u7528\u4e00\u4e9b\u5e38\u7528\u7684\u6570\u636e\u5206\u6790\u5e93\uff0c\u5982 <code>pandas<\/code> \u548c <code>scikit-learn<\/code>\u3002\u9996\u5148\uff0c\u8ba9\u6211\u4eec\u521b\u5efa\u4e00\u4e2a\u793a\u4f8bDataFrame\u6765\u6a21\u62df\u539f\u59cb\u6570\u636e\uff0c\u5e76\u9010\u6b65\u5e94\u7528\u8fd9\u4e9b\u5206\u6790\u4efb\u52a1\u3002<\/p>\n\n\n\n<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_71 counter-hierarchy ez-toc-counter ez-toc-grey ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\">\n<p class=\"ez-toc-title\" style=\"cursor:inherit\">\u6587\u7ae0\u76ee\u5f55<\/p>\n<span class=\"ez-toc-title-toggle\"><a href=\"#\" class=\"ez-toc-pull-right ez-toc-btn ez-toc-btn-xs ez-toc-btn-default ez-toc-toggle\" aria-label=\"Toggle Table of Content\"><span class=\"ez-toc-js-icon-con\"><span class=\"\"><span class=\"eztoc-hide\" style=\"display:none;\">Toggle<\/span><span class=\"ez-toc-icon-toggle-span\"><svg style=\"fill: #999;color:#999\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" class=\"list-377408\" width=\"20px\" height=\"20px\" viewBox=\"0 0 24 24\" fill=\"none\"><path d=\"M6 6H4v2h2V6zm14 0H8v2h12V6zM4 11h2v2H4v-2zm16 0H8v2h12v-2zM4 16h2v2H4v-2zm16 0H8v2h12v-2z\" fill=\"currentColor\"><\/path><\/svg><svg style=\"fill: #999;color:#999\" class=\"arrow-unsorted-368013\" xmlns=\"http:\/\/www.w3.org\/2000\/svg\" width=\"10px\" height=\"10px\" viewBox=\"0 0 24 24\" version=\"1.2\" baseProfile=\"tiny\"><path d=\"M18.2 9.3l-6.2-6.3-6.2 6.3c-.2.2-.3.4-.3.7s.1.5.3.7c.2.2.4.3.7.3h11c.3 0 .5-.1.7-.3.2-.2.3-.5.3-.7s-.1-.5-.3-.7zM5.8 14.7l6.2 6.3 6.2-6.3c.2-.2.3-.5.3-.7s-.1-.5-.3-.7c-.2-.2-.4-.3-.7-.3h-11c-.3 0-.5.1-.7.3-.2.2-.3.5-.3.7s.1.5.3.7z\"\/><\/svg><\/span><\/span><\/span><\/a><\/span><\/div>\n<nav><ul class='ez-toc-list ez-toc-list-level-1 eztoc-toggle-hide-by-default' ><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#%E5%88%9B%E5%BB%BA%E7%A4%BA%E4%BE%8B%E6%95%B0%E6%8D%AE\" title=\"\u521b\u5efa\u793a\u4f8b\u6570\u636e\">\u521b\u5efa\u793a\u4f8b\u6570\u636e<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#1_%E6%89%BE%E5%87%BA%E9%94%80%E5%94%AE%E9%A2%9D%E6%9C%80%E9%AB%98%E7%9A%84Top_10%E5%95%86%E5%93%81\" title=\"1. \u627e\u51fa\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1\">1. \u627e\u51fa\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#2_%E5%88%86%E6%9E%90%E5%90%84%E5%9C%B0%E5%8C%BA%E9%94%80%E5%94%AE%E5%B7%AE%E5%BC%82\" title=\"2. \u5206\u6790\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02\">2. \u5206\u6790\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#3_%E8%AF%86%E5%88%AB%E9%AB%98%E4%BB%B7%E5%80%BC%E7%94%A8%E6%88%B7%E7%BE%A4%E4%BD%93%EF%BC%88RFM%E6%A8%A1%E5%9E%8B%EF%BC%89\" title=\"3. \u8bc6\u522b\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RFM\u6a21\u578b\uff09\">3. \u8bc6\u522b\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RFM\u6a21\u578b\uff09<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#4_%E5%88%86%E6%9E%90%E4%BF%83%E9%94%80%E6%B4%BB%E5%8A%A8%E7%9A%84%E6%8B%89%E5%8A%A8%E6%95%88%E6%9E%9C\" title=\"4. \u5206\u6790\u4fc3\u9500\u6d3b\u52a8\u7684\u62c9\u52a8\u6548\u679c\">4. \u5206\u6790\u4fc3\u9500\u6d3b\u52a8\u7684\u62c9\u52a8\u6548\u679c<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#5_%E5%88%86%E6%9E%90%E6%96%B0%E5%93%81%E4%B8%8A%E5%B8%82%E5%AF%B9%E8%80%81%E5%93%81%E7%9A%84%E5%86%B2%E5%87%BB\" title=\"5. \u5206\u6790\u65b0\u54c1\u4e0a\u5e02\u5bf9\u8001\u54c1\u7684\u51b2\u51fb\">5. \u5206\u6790\u65b0\u54c1\u4e0a\u5e02\u5bf9\u8001\u54c1\u7684\u51b2\u51fb<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#6_%E5%88%86%E6%9E%90%E9%80%80%E8%B4%A7%E7%8E%87%E4%B8%8E%E5%95%86%E5%93%81%E7%B1%BB%E5%88%AB%E7%9A%84%E5%85%B3%E7%B3%BB\" title=\"6. \u5206\u6790\u9000\u8d27\u7387\u4e0e\u5546\u54c1\u7c7b\u522b\u7684\u5173\u7cfb\">6. \u5206\u6790\u9000\u8d27\u7387\u4e0e\u5546\u54c1\u7c7b\u522b\u7684\u5173\u7cfb<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#7_%E5%88%86%E6%9E%90%E7%94%A8%E6%88%B7%E5%A4%8D%E8%B4%AD%E8%B7%AF%E5%BE%84\" title=\"7. \u5206\u6790\u7528\u6237\u590d\u8d2d\u8def\u5f84\">7. \u5206\u6790\u7528\u6237\u590d\u8d2d\u8def\u5f84<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#8_%E5%88%86%E6%9E%90%E8%8A%82%E5%81%87%E6%97%A5%E5%89%8D%E5%90%8E%E9%94%80%E5%94%AE%E6%B3%A2%E5%8A%A8\" title=\"8. \u5206\u6790\u8282\u5047\u65e5\u524d\u540e\u9500\u552e\u6ce2\u52a8\">8. \u5206\u6790\u8282\u5047\u65e5\u524d\u540e\u9500\u552e\u6ce2\u52a8<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#9_%E5%88%86%E6%9E%90%E6%B5%81%E9%87%8F%E4%B8%8E%E8%BD%AC%E5%8C%96%E7%8E%87%E4%B9%8B%E9%97%B4%E7%9A%84%E5%85%B3%E7%B3%BB\" title=\"9. \u5206\u6790\u6d41\u91cf\u4e0e\u8f6c\u5316\u7387\u4e4b\u95f4\u7684\u5173\u7cfb\">9. \u5206\u6790\u6d41\u91cf\u4e0e\u8f6c\u5316\u7387\u4e4b\u95f4\u7684\u5173\u7cfb<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/#10_%E5%88%86%E6%9E%90%E4%B8%8D%E5%90%8C%E5%B9%B3%E5%8F%B0%E6%B8%A0%E9%81%93%E7%9A%84%E7%94%A8%E6%88%B7%E7%94%BB%E5%83%8F%E5%B7%AE%E5%BC%82\" title=\"10. \u5206\u6790\u4e0d\u540c\u5e73\u53f0\u6e20\u9053\u7684\u7528\u6237\u753b\u50cf\u5dee\u5f02\">10. \u5206\u6790\u4e0d\u540c\u5e73\u53f0\u6e20\u9053\u7684\u7528\u6237\u753b\u50cf\u5dee\u5f02<\/a><\/li><\/ul><\/nav><\/div>\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"%E5%88%9B%E5%BB%BA%E7%A4%BA%E4%BE%8B%E6%95%B0%E6%8D%AE\"><\/span>\u521b\u5efa\u793a\u4f8b\u6570\u636e<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code>import pandas as pd\nimport numpy as np\n\n# \u521b\u5efa\u793a\u4f8b\u65f6\u95f4\u5e8f\u5217\u6570\u636e\ndates = pd.date_range(start='2023-01-01', end='2025-06-30', freq='D')\nnp.random.seed(42)\nsales_data = np.cumsum(np.random.normal(loc=100, scale=20, size=len(dates)))\n\ndata = {\n    'order_id': range(1, len(dates) + 1),\n    'product_id': np.random.choice(&#91;'P{}'.format(i) for i in range(1, 101)], len(dates)),\n    'category_code': np.random.choice(&#91;'C{}'.format(i) for i in range(1, 11)], len(dates)),\n    'amount': sales_data,\n    'quantity': np.random.randint(1, 5, size=len(dates)),\n    'order_date': dates,\n    'customer_id': np.random.randint(1, 1001, size=len(dates)),\n    'region': np.random.choice(&#91;'Beijing', 'Shanghai', 'Guangzhou', 'Shenzhen'], len(dates)),\n    'promotion': np.random.choice(&#91;True, False], len(dates)),\n    'return_status': np.random.choice(&#91;True, False], len(dates)),\n    'platform_channel': np.random.choice(&#91;'Online', 'Offline'], len(dates))\n}\n\ndf = pd.DataFrame(data)\n\nprint(\"\u539f\u59cb\u6570\u636e:\")\nprint(df.head())<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"1_%E6%89%BE%E5%87%BA%E9%94%80%E5%94%AE%E9%A2%9D%E6%9C%80%E9%AB%98%E7%9A%84Top_10%E5%95%86%E5%93%81\"><\/span>1. \u627e\u51fa\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u6309\u4ea7\u54c1ID\u805a\u5408\u9500\u552e\u989d\ntop_products = df.groupby('product_id')&#91;'amount'].sum().sort_values(ascending=False).head(10)\n\nprint(\"\\n\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1:\")\nprint(top_products)<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"2_%E5%88%86%E6%9E%90%E5%90%84%E5%9C%B0%E5%8C%BA%E9%94%80%E5%94%AE%E5%B7%AE%E5%BC%82\"><\/span>2. \u5206\u6790\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u6309\u5730\u533a\u805a\u5408\u9500\u552e\u989d\nregion_sales = df.groupby('region')&#91;'amount'].sum()\n\nprint(\"\\n\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02:\")\nprint(region_sales)<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"3_%E8%AF%86%E5%88%AB%E9%AB%98%E4%BB%B7%E5%80%BC%E7%94%A8%E6%88%B7%E7%BE%A4%E4%BD%93%EF%BC%88RFM%E6%A8%A1%E5%9E%8B%EF%BC%89\"><\/span>3. \u8bc6\u522b\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RFM\u6a21\u578b\uff09<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code>from datetime import datetime\n\n# \u8ba1\u7b97\u6700\u8fd1\u4e00\u6b21\u8d2d\u4e70\u65e5\u671f\u3001\u8d2d\u4e70\u9891\u7387\u548c\u603b\u6d88\u8d39\u91d1\u989d\nrfm_df = df.groupby('customer_id').agg({\n    'order_date': lambda x: (datetime.now() - x.max()).days,  # Recency\n    'order_id': 'count',                                    # Frequency\n    'amount': 'sum'                                         # Monetary\n}).reset_index()\n\nrfm_df.rename(columns={\n    'order_date': 'Recency',\n    'order_id': 'Frequency',\n    'amount': 'Monetary'\n}, inplace=True)\n\n# \u6807\u51c6\u5316\u6bcf\u4e2a\u7279\u5f81\nfrom sklearn.preprocessing import StandardScaler\n\nscaler = StandardScaler()\nrfm_scaled = scaler.fit_transform(rfm_df&#91;&#91;'Recency', 'Frequency', 'Monetary']])\n\n# \u4f7f\u7528KMeans\u805a\u7c7b\nfrom sklearn.cluster import KMeans\n\nkmeans = KMeans(n_clusters=5, random_state=42)\nrfm_df&#91;'Cluster'] = kmeans.fit_predict(rfm_scaled)\n\n# \u67e5\u770b\u6bcf\u4e2a\u7c07\u7684\u5e73\u5747\u503c\ncluster_analysis = rfm_df.groupby('Cluster').mean()\n\nprint(\"\\n\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RFM\u6a21\u578b\uff09:\")\nprint(cluster_analysis)<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"4_%E5%88%86%E6%9E%90%E4%BF%83%E9%94%80%E6%B4%BB%E5%8A%A8%E7%9A%84%E6%8B%89%E5%8A%A8%E6%95%88%E6%9E%9C\"><\/span>4. \u5206\u6790\u4fc3\u9500\u6d3b\u52a8\u7684\u62c9\u52a8\u6548\u679c<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u6309\u4fc3\u9500\u72b6\u6001\u805a\u5408\u9500\u552e\u989d\npromotion_effect = df.groupby('promotion')&#91;'amount'].sum()\n\nprint(\"\\n\u4fc3\u9500\u6d3b\u52a8\u7684\u62c9\u52a8\u6548\u679c:\")\nprint(promotion_effect)<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"5_%E5%88%86%E6%9E%90%E6%96%B0%E5%93%81%E4%B8%8A%E5%B8%82%E5%AF%B9%E8%80%81%E5%93%81%E7%9A%84%E5%86%B2%E5%87%BB\"><\/span>5. \u5206\u6790\u65b0\u54c1\u4e0a\u5e02\u5bf9\u8001\u54c1\u7684\u51b2\u51fb<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u5047\u8bbe\u65b0\u54c1\u662f\u57282024\u5e741\u67081\u65e5\u4e0a\u5e02\nnew_product_ids = df&#91;df&#91;'order_date'] &gt;= '2024-01-01']&#91;'product_id'].unique()\nold_product_ids = df&#91;df&#91;'order_date'] &lt; '2024-01-01']&#91;'product_id'].unique()\n\n# \u65b0\u54c1\u57282024\u5e74\u7684\u9500\u552e\u989d\nnew_product_sales = df&#91;df&#91;'product_id'].isin(new_product_ids) &amp; (df&#91;'order_date'] &gt;= '2024-01-01')].groupby('product_id')&#91;'amount'].sum()\n\n# \u8001\u54c1\u57282024\u5e74\u7684\u9500\u552e\u989d\nold_product_sales = df&#91;df&#91;'product_id'].isin(old_product_ids) &amp; (df&#91;'order_date'] &gt;= '2024-01-01')].groupby('product_id')&#91;'amount'].sum()\n\nprint(\"\\n\u65b0\u54c1\u57282024\u5e74\u7684\u9500\u552e\u989d:\")\nprint(new_product_sales)\nprint(\"\\n\u8001\u54c1\u57282024\u5e74\u7684\u9500\u552e\u989d:\")\nprint(old_product_sales)<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"6_%E5%88%86%E6%9E%90%E9%80%80%E8%B4%A7%E7%8E%87%E4%B8%8E%E5%95%86%E5%93%81%E7%B1%BB%E5%88%AB%E7%9A%84%E5%85%B3%E7%B3%BB\"><\/span>6. \u5206\u6790\u9000\u8d27\u7387\u4e0e\u5546\u54c1\u7c7b\u522b\u7684\u5173\u7cfb<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u8ba1\u7b97\u6bcf\u4e2a\u7c7b\u522b\u7684\u9000\u8d27\u7387\nreturn_rates = df.groupby('category_code').agg({\n    'return_status': 'mean',\n    'amount': 'sum'\n})\n\nreturn_rates.rename(columns={'return_status': 'Return_Rate'}, inplace=True)\n\nprint(\"\\n\u9000\u8d27\u7387\u4e0e\u5546\u54c1\u7c7b\u522b\u7684\u5173\u7cfb:\")\nprint(return_rates)<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"7_%E5%88%86%E6%9E%90%E7%94%A8%E6%88%B7%E5%A4%8D%E8%B4%AD%E8%B7%AF%E5%BE%84\"><\/span>7. \u5206\u6790\u7528\u6237\u590d\u8d2d\u8def\u5f84<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u8ba1\u7b97\u6bcf\u4e2a\u7528\u6237\u7684\u8ba2\u5355\u6b21\u6570\nuser_orders = df.groupby('customer_id')&#91;'order_id'].count().reset_index()\nuser_orders.columns = &#91;'customer_id', 'Order_Count']\n\n# \u7b5b\u9009\u51fa\u590d\u8d2d\u7528\u6237\nrepeat_customers = user_orders&#91;user_orders&#91;'Order_Count'] &gt; 1]\n\nprint(\"\\n\u590d\u8d2d\u7528\u6237\u6570\u91cf:\")\nprint(len(repeat_customers))\n\n# \u67e5\u770b\u590d\u8d2d\u7528\u6237\u7684\u8be6\u7ec6\u4fe1\u606f\nrepeat_customer_details = df&#91;df&#91;'customer_id'].isin(repeat_customers&#91;'customer_id'])]\nprint(\"\\n\u590d\u8d2d\u7528\u6237\u7684\u8be6\u7ec6\u4fe1\u606f:\")\nprint(repeat_customer_details.head())<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"8_%E5%88%86%E6%9E%90%E8%8A%82%E5%81%87%E6%97%A5%E5%89%8D%E5%90%8E%E9%94%80%E5%94%AE%E6%B3%A2%E5%8A%A8\"><\/span>8. \u5206\u6790\u8282\u5047\u65e5\u524d\u540e\u9500\u552e\u6ce2\u52a8<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u6dfb\u52a0\u8282\u5047\u65e5\u6807\u5fd7\nholidays = pd.to_datetime(&#91;\n    '2023-01-01', '2023-02-22', '2023-04-05', '2023-05-01', '2023-10-01',\n    '2024-01-01', '2024-02-10', '2024-04-04', '2024-05-01', '2024-10-01',\n    '2025-01-01', '2025-02-19', '2025-04-04', '2025-05-01', '2025-10-01'\n])\n\ndf&#91;'is_holiday'] = df&#91;'order_date'].isin(holidays).astype(int)\n\n# \u6309\u662f\u5426\u662f\u8282\u5047\u65e5\u805a\u5408\u9500\u552e\u989d\nholiday_sales = df.groupby('is_holiday')&#91;'amount'].sum()\n\nprint(\"\\n\u8282\u5047\u65e5\u524d\u540e\u9500\u552e\u6ce2\u52a8:\")\nprint(holiday_sales)<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"9_%E5%88%86%E6%9E%90%E6%B5%81%E9%87%8F%E4%B8%8E%E8%BD%AC%E5%8C%96%E7%8E%87%E4%B9%8B%E9%97%B4%E7%9A%84%E5%85%B3%E7%B3%BB\"><\/span>9. \u5206\u6790\u6d41\u91cf\u4e0e\u8f6c\u5316\u7387\u4e4b\u95f4\u7684\u5173\u7cfb<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<p>\u5047\u8bbe\u6211\u4eec\u6709\u4e00\u4e2a\u8bbf\u95ee\u8bb0\u5f55\u7684DataFrame\uff0c\u7528\u4e8e\u8ba1\u7b97\u8f6c\u5316\u7387\u3002<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code># \u521b\u5efa\u8bbf\u95ee\u8bb0\u5f55\u7684DataFrame\nvisit_data = {\n    'customer_id': np.random.randint(1, 1001, size=len(dates)),\n    'visits': np.random.randint(1, 10, size=len(dates)),\n    'order_date': dates\n}\ndf_visits = pd.DataFrame(visit_data)\n\n# \u5408\u5e76\u8ba2\u5355\u548c\u8bbf\u95ee\u6570\u636e\nmerged_df = pd.merge(df, df_visits, on=&#91;'customer_id', 'order_date'], how='right')\n\n# \u586b\u5145\u7f3a\u5931\u7684\u8ba2\u5355\u91d1\u989d\u4e3a0\nmerged_df&#91;'amount'].fillna(0, inplace=True)\n\n# \u8ba1\u7b97\u8f6c\u5316\u7387\nconversion_rate = merged_df.groupby('customer_id').agg({\n    'amount': lambda x: (x &gt; 0).sum(),\n    'visits': 'sum'\n}).reset_index()\n\nconversion_rate&#91;'Conversion_Rate'] = conversion_rate&#91;'amount'] \/ conversion_rate&#91;'visits']\n\nprint(\"\\n\u6d41\u91cf\u4e0e\u8f6c\u5316\u7387\u4e4b\u95f4\u7684\u5173\u7cfb:\")\nprint(conversion_rate.head())<\/code><\/pre>\n\n\n\n<h3 class=\"wp-block-heading\"><span class=\"ez-toc-section\" id=\"10_%E5%88%86%E6%9E%90%E4%B8%8D%E5%90%8C%E5%B9%B3%E5%8F%B0%E6%B8%A0%E9%81%93%E7%9A%84%E7%94%A8%E6%88%B7%E7%94%BB%E5%83%8F%E5%B7%AE%E5%BC%82\"><\/span>10. \u5206\u6790\u4e0d\u540c\u5e73\u53f0\u6e20\u9053\u7684\u7528\u6237\u753b\u50cf\u5dee\u5f02<span class=\"ez-toc-section-end\"><\/span><\/h3>\n\n\n\n<pre class=\"wp-block-code\"><code># \u6309\u5e73\u53f0\u6e20\u9053\u805a\u5408\u9500\u552e\u989d\u548c\u5176\u4ed6\u6307\u6807\nchannel_analysis = df.groupby('platform_channel').agg({\n    'amount': 'sum',\n    'customer_id': 'nunique',\n    'order_id': 'count'\n}).reset_index()\n\nchannel_analysis.rename(columns={\n    'customer_id': 'Unique_Customers',\n    'order_id': 'Total_Orders'\n}, inplace=True)\n\nprint(\"\\n\u4e0d\u540c\u5e73\u53f0\u6e20\u9053\u7684\u7528\u6237\u753b\u50cf\u5dee\u5f02:\")\nprint(channel_analysis)<\/code><\/pre>\n\n\n\n<p>\u7efc\u5408\u4ee5\u4e0a\u6b65\u9aa4\uff0c\u6700\u7ec8\u7684\u5206\u6790\u7ed3\u679c\u5982\u4e0b\uff1a<\/p>\n\n\n\n<p>\u8fd9\u6bb5\u4ee3\u7801\u5c55\u793a\u4e86\u4ece\u539f\u59cb\u6570\u636e\u5230\u7ecf\u8fc7\u5168\u9762\u5206\u6790\u7684\u7ed3\u679c\u7684\u8fc7\u7a0b\u3002\u4f60\u53ef\u4ee5\u6839\u636e\u5b9e\u9645\u9700\u6c42\u8c03\u6574\u6bcf\u4e00\u6b65\u7684\u64cd\u4f5c\u3002<\/p>\n\n\n\n<p><\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>import pandas as pd\nimport numpy as np\nfrom datetime import datetime\nfrom sklearn.preprocessing import StandardScaler\nfrom sklearn.cluster import KMeans\n\n# \u521b\u5efa\u793a\u4f8b\u65f6\u95f4\u5e8f\u5217\u6570\u636e\ndates = pd.date_range(start='2023-01-01', end='2025-06-30', freq='D')\nnp.random.seed(42)\nsales_data = np.cumsum(np.random.normal(loc=100, scale=20, size=len(dates)))\n\ndata = {\n    'order_id': range(1, len(dates) + 1),\n    'product_id': np.random.choice(&#91;'P{}'.format(i) for i in range(1, 101)], len(dates)),\n    'category_code': np.random.choice(&#91;'C{}'.format(i) for i in range(1, 11)], len(dates)),\n    'amount': sales_data,\n    'quantity': np.random.randint(1, 5, size=len(dates)),\n    'order_date': dates,\n    'customer_id': np.random.randint(1, 1001, size=len(dates)),\n    'region': np.random.choice(&#91;'Beijing', 'Shanghai', 'Guangzhou', 'Shenzhen'], len(dates)),\n    'promotion': np.random.choice(&#91;True, False], len(dates)),\n    'return_status': np.random.choice(&#91;True, False], len(dates)),\n    'platform_channel': np.random.choice(&#91;'Online', 'Offline'], len(dates))\n}\n\ndf = pd.DataFrame(data)\n\n# \u627e\u51fa\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1\ntop_products = df.groupby('product_id')&#91;'amount'].sum().sort_values(ascending=False).head(10)\n\n# \u5206\u6790\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02\nregion_sales = df.groupby('region')&#91;'amount'].sum()\n\n# \u8bc6\u522b\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RFM\u6a21\u578b\uff09\nrfm_df = df.groupby('customer_id').agg({\n    'order_date': lambda x: (datetime.now() - x.max()).days,  # Recency\n    'order_id': 'count',                                    # Frequency\n    'amount': 'sum'                                         # Monetary\n}).reset_index()\n\nrfm_df.rename(columns={\n    'order_date': 'Recency',\n    'order_id': 'Frequency',\n    'amount': 'Monetary'\n}, inplace=True)\n\nscaler = StandardScaler()\nrfm_scaled = scaler.fit_transform(rfm_df&#91;&#91;'Recency', 'Frequency', 'Monetary']])\n\nkmeans = KMeans(n_clusters=5, random_state=42)\nrfm_df&#91;'Cluster'] = kmeans.fit_predict(rfm_scaled)\n\ncluster_analysis = rfm_df.groupby('Cluster').mean()\n\n# \u5206\u6790\u4fc3\u9500\u6d3b\u52a8\u7684\u62c9\u52a8\u6548\u679c\npromotion_effect = df.groupby('promotion')&#91;'amount'].sum()\n\n# \u5206\u6790\u65b0\u54c1\u4e0a\u5e02\u5bf9\u8001\u54c1\u7684\u51b2\u51fb\nnew_product_ids = df&#91;df&#91;'order_date'] &gt;= '2024-01-01']&#91;'product_id'].unique()\nold_product_ids = df&#91;df&#91;'order_date'] &lt; '2024-01-01']&#91;'product_id'].unique()\n\nnew_product_sales = df&#91;df&#91;'product_id'].isin(new_product_ids) &amp; (df&#91;'order_date'] &gt;= '2024-01-01')].groupby('product_id')&#91;'amount'].sum()\nold_product_sales = df&#91;df&#91;'product_id'].isin(old_product_ids) &amp; (df&#91;'order_date'] &gt;= '2024-01-01')].groupby('product_id')&#91;'amount'].sum()\n\n# \u5206\u6790\u9000\u8d27\u7387\u4e0e\u5546\u54c1\u7c7b\u522b\u7684\u5173\u7cfb\nreturn_rates = df.groupby('category_code').agg({\n    'return_status': 'mean',\n    'amount': 'sum'\n})\nreturn_rates.rename(columns={'return_status': 'Return_Rate'}, inplace=True)\n\n# \u5206\u6790\u7528\u6237\u590d\u8d2d\u8def\u5f84\nuser_orders = df.groupby('customer_id')&#91;'order_id'].count().reset_index()\nuser_orders.columns = &#91;'customer_id', 'Order_Count']\nrepeat_customers = user_orders&#91;user_orders&#91;'Order_Count'] &gt; 1]\nrepeat_customer_details = df&#91;df&#91;'customer_id'].isin(repeat_customers&#91;'customer_id'])]\n\n# \u5206\u6790\u8282\u5047\u65e5\u524d\u540e\u9500\u552e\u6ce2\u52a8\nholidays = pd.to_datetime(&#91;\n    '2023-01-01', '2023-02-22', '2023-04-05', '2023-05-01', '2023-10-01',\n    '2024-01-01', '2024-02-10', '2024-04-04', '2024-05-01', '2024-10-01',\n    '2025-01-01', '2025-02-19', '2025-04-04', '2025-05-01', '2025-10-01'\n])\ndf&#91;'is_holiday'] = df&#91;'order_date'].isin(holidays).astype(int)\nholiday_sales = df.groupby('is_holiday')&#91;'amount'].sum()\n\n# \u5206\u6790\u6d41\u91cf\u4e0e\u8f6c\u5316\u7387\u4e4b\u95f4\u7684\u5173\u7cfb\nvisit_data = {\n    'customer_id': np.random.randint(1, 1001, size=len(dates)),\n    'visits': np.random.randint(1, 10, size=len(dates)),\n    'order_date': dates\n}\ndf_visits = pd.DataFrame(visit_data)\nmerged_df = pd.merge(df, df_visits, on=&#91;'customer_id', 'order_date'], how='right')\nmerged_df&#91;'amount'].fillna(0, inplace=True)\nconversion_rate = merged_df.groupby('customer_id').agg({\n    'amount': lambda x: (x &gt; 0).sum(),\n    'visits': 'sum'\n}).reset_index()\nconversion_rate&#91;'Conversion_Rate'] = conversion_rate&#91;'amount'] \/ conversion_rate&#91;'visits']\n\n# \u5206\u6790\u4e0d\u540c\u5e73\u53f0\u6e20\u9053\u7684\u7528\u6237\u753b\u50cf\u5dee\u5f02\nchannel_analysis = df.groupby('platform_channel').agg({\n    'amount': 'sum',\n    'customer_id': 'nunique',\n    'order_id': 'count'\n}).reset_index()\nchannel_analysis.rename(columns={\n    'customer_id': 'Unique_Customers',\n    'order_id': 'Total_Orders'\n}, inplace=True)\n\nprint(\"\u539f\u59cb\u6570\u636e:\")\nprint(df.head())\n\nprint(\"\\n\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1:\")\nprint(top_products)\n\nprint(\"\\n\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02:\")\nprint(region_sales)\n\nprint(\"\\n\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RFM\u6a21\u578b\uff09:\")\nprint(cluster_analysis)\n\nprint(\"\\n\u4fc3\u9500\u6d3b\u52a8\u7684\u62c9\u52a8\u6548\u679c:\")\nprint(promotion_effect)\n\nprint(\"\\n\u65b0\u54c1\u57282024\u5e74\u7684\u9500\u552e\u989d:\")\nprint(new_product_sales)\nprint(\"\\n\u8001\u54c1\u57282024\u5e74\u7684\u9500\u552e\u989d:\")\nprint(old_product_sales)\n\nprint(\"\\n\u9000\u8d27\u7387\u4e0e\u5546\u54c1\u7c7b\u522b\u7684\u5173\u7cfb:\")\nprint(return_rates)\n\nprint(\"\\n\u590d\u8d2d\u7528\u6237\u6570\u91cf:\")\nprint(len(repeat_customers))\nprint(\"\\n\u590d\u8d2d\u7528\u6237\u7684\u8be6\u7ec6\u4fe1\u606f:\")\nprint(repeat_customer_details.head())\n\nprint(\"\\n\u8282\u5047\u65e5\u524d\u540e\u9500\u552e\u6ce2\u52a8:\")\nprint(holiday_sales)\n\nprint(\"\\n\u6d41\u91cf\u4e0e\u8f6c\u5316\u7387\u4e4b\u95f4\u7684\u5173\u7cfb:\")\nprint(conversion_rate.head())\n\nprint(\"\\n\u4e0d\u540c\u5e73\u53f0\u6e20\u9053\u7684\u7528\u6237\u753b\u50cf\u5dee\u5f02:\")\nprint(channel_analysis)\n\n\n\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u5de5\u4f5c\u5e38\u7528\u7684\u5206\u6790\u7ed3\u679c\u6848\u4f8b\uff1a \u627e\u51fa\u9500\u552e\u989d\u6700\u9ad8\u7684Top 10\u5546\u54c1\u5206\u6790\u5404\u5730\u533a\u9500\u552e\u5dee\u5f02\u8bc6\u522b\u9ad8\u4ef7\u503c\u7528\u6237\u7fa4\u4f53\uff08RF&hellip; <a href=\"http:\/\/viplao.com\/index.php\/2025\/06\/28\/%e3%80%90python%e5%ae%9e%e8%b7%b5%e7%bb%8f%e9%aa%8c%e3%80%91%e7%94%b5%e5%95%86%e5%b9%b3%e5%8f%b0%e9%94%80%e5%94%ae%e6%95%b0%e6%8d%ae%e5%88%86%e6%9e%90%e5%ae%9e%e8%b7%b5-%e5%88%86%e6%9e%90\/\" class=\"more-link read-more\" rel=\"bookmark\">\u7ee7\u7eed\u9605\u8bfb <span class=\"screen-reader-text\">\u3010Python10\u5e74\u7ecf\u9a8c\u603b\u7ed3\u3011\u7b2c\u516d\u8bfe \u7535\u5546\u5e73\u53f0\u9500\u552e\u6570\u636e\u5206\u6790\u5b9e\u8df5 \u2013 \u5206\u6790\u7ed3\u679c\uff08Analysis Insights\uff09<\/span><i class=\"fa fa-arrow-right\"><\/i><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[1],"tags":[28],"views":767,"_links":{"self":[{"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/posts\/3545"}],"collection":[{"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/comments?post=3545"}],"version-history":[{"count":3,"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/posts\/3545\/revisions"}],"predecessor-version":[{"id":3564,"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/posts\/3545\/revisions\/3564"}],"wp:attachment":[{"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/media?parent=3545"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/categories?post=3545"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/viplao.com\/index.php\/wp-json\/wp\/v2\/tags?post=3545"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}