跳到主要內容

如何利用 Python 爬蟲實現給微信群發新聞早報?(詳細)_台中搬家


台中搬家公司費用怎麼算?



擁有20年純熟搬遷經驗,提供免費估價且流程透明更是5星評價的搬家公司




1. 場景


經常有小夥伴在交流群問我,每天的早報新聞是怎麼獲取的?


其實,早期使用的方案,是利用爬蟲獲取到一些新聞網站的標題,然後做了一些簡單的數據清洗,最後利用 itchat 發送到指定的社群中。


由於爬蟲面對 網站改版的不穩定性及 itchat 不安全性,所以放棄了這種方案


後期更改了一種方案,通過修改爬蟲方案,創建 API 服務,編寫 App 去獲取數據,然後手動發送到微信群


本篇文章將和大家詳細聊聊具體的實現過程


2. 數據爬取


第 1 步,通過 Python 爬蟲獲取數據


獲取方式有 2 種,分別是:已有的新聞早報網站、新聞網站的頭條新聞


選擇一種爬蟲方式,就能很快地爬取到目標網站的數據


第 2 步,數據清洗,排序


將爬取到的數據先進行一次關鍵字篩選,然後按照點贊或者閱讀數按照熱點進行排序


第 3 步,參數化,去重


去掉數據中重複的新聞,然後將最後展示的數目參數化


# 按照點贊數目,降序排列
news_sorted_pro = sorted(news, key=itemgetter('news_approve_num'), reverse=True)

result = []

for news_sorted_item in news_sorted_pro:
      result.append(news_sorted_item.get('title'))

# 去重
result = sorted(set(result), key=result.index)

# 只取前12條數據
result = result[:self.news_num] if len(result) >= self.news_num else result

需要注意的是,由於新聞網站會經常改版,建議爬取多個新聞網站,做好異常處理,做一個優先級,如果一個網站爬取數據失敗,切換到下一個級別的網站爬取數據


3. 服務化


將數據服務化,即編寫 API,目的是為了方便終端調用


如果使用 Python 編寫 API,建議使用 FastAPI 或 Flask 框架,因為這兩個框架開發 API 方便快捷,以 FastAPI 為例:


第 1 步,安裝依賴


包含 FastAPI 框架及 hypercorn 依賴,hypercorn 是獨立的 ASGI 服務器,方便 FastAPI 項目的部署


# FastAPI框架
pip3 install fastapi

pip3 install hypercorn

第 2 步,編寫 API


使用 FastAPI 很方便,不到 10 行代碼就能編寫一個接口服務


只需要實例化 FastAPI 對象,利用裝飾器指定請求方法和路徑即可,調用上面的爬蟲方法即可。


from fastapi import FastAPI

# 實例化
app = FastAPI()

# API,Get方式
@app.get("/last_news")
def get_last_news():
    """
    最新的新聞
    :return:
    """
    news = get_news()

    data = {
        'code': 0,
        'news': news
    }

    # 封裝
    return data

如要想本地調試 API,可以通過 uvicorn 命令運行項目


# 運行項目
uvicorn news:app --reload

然後訪問下面的地址,查看返回的新聞數據


http://127.0.0.1:8000/last_news


台中搬家遵守搬運三大原則,讓您的家具不再被破壞!



台中搬家公司推薦超過30年經驗,首選台中大展搬家





第 3 步,生成依賴遷移文件


使用 pip freeze 命令將在本地生成依賴遷移文件


# 生成遷移文件
pip freeze > requirements.txt

第 4 步,上傳代碼


將代碼上傳到代碼託管平台,比如:碼雲、GitLab 等


第 5 步,服務器拉取代碼


服務器中通過 git 拉取代碼,並通過依賴文件一鍵安裝所有依賴


# 安裝依賴
pip3 install -r requirements.txt

第 6 步,運行服務


使用 hypercorn 運行 FastAPI 項目,使進程一直在後台運行,並保存運行日誌信息


# 後台運行
# 保存日誌,綁定端口號為:8000
# nohup hypercorn news:app --bind 0.0.0.0:8000 > /news.log 2>&1 &

需要注意的是,項目綁定的端口號需要在防火牆和雲服務器安全組開啟


當然,如果使用 Java 編寫 API,推薦使用 Spring Boot,可以快速開發一個 Restful API 服務


4. 編寫 App


完成 API 服務之後,接下來就是在終端編寫一款 App 去訪問 API,拿到數據並展示出來


以編寫一款 Android 應用為例


首先,我們在界面上放置一個文本显示框和一個按鈕控件


然後,對按鈕控件設置點擊事件的監聽


get_news_btn = findViewById(R.id.get_news_btn);

//監聽事件
get_news_btn.setOnClickListener(this);

@Override
public void onClick(View v)
{
    switch (v.getId())
    {
        case R.id.get_news_btn:
            news_et.setText("獲取中。。。");
            getNewsMet();
            break;
        }
    }

接着,使用 Android 的網絡請求框架 OkHttp 框架調用 API 獲取數據


/***
* 獲取新聞
*/
private void getNewsMet()
{
     OkHttpClient okHttpClient = new OkHttpClient();
     //構建請求信息:連接請求url 請求方法method 請求頭部headers 請求體body 標籤tag
     Request request = new Request.Builder().url(url).get().build();
//        Call call = okHttpClient.newCall(request);

     okHttpClient.newCall(request).enqueue(new Callback()
     {
          @Override
          public void onFailure(Call call, IOException e)
          {
              Log.d("xag", "獲取失敗");
              showResult(false, "");
          }

          @Override
          public void onResponse(Call call, final Response response) throws IOException
          {
              Log.d("xag", "獲取成功")
              parseJsonWithJsonObject(response);
          }
      });
}

最後,將新聞數據显示在文本控件中,並複製到系統剪切板


private void copyToClip(String content)
{
     //獲取剪貼板管理器:
     ClipboardManager cm = (ClipboardManager) getSystemService(CLIPBOARD_SERVICE);
     // 創建普通字符型ClipData
     ClipData mClipData = ClipData.newPlainText("Label", content);
     // 將ClipData內容放到系統剪貼板里。
     if (null != cm)
     {
         cm.setPrimaryClip(mClipData);
     }
}

如果只有 iOS 設備,使用 Xcode 編寫 iOS 應用,建議將 Xcode 升級到 11.0 以上


創建項目的時候,推薦使用 SwiftUI 構建 UI 界面,然後利用 CocoaPods 添加 Alamofire 網絡請求依賴庫,其他操作步驟和 Android 端類似,這裏不展開說明


# Uncomment the next line to define a global platform for your project
source 'https://github.com/CocoaPods/Specs.git'

platform :ios, '9.0'

use_frameworks!

target 'news_eve' do
  # Comment the next line if you don't want to use dynamic frameworks
  pod 'Alamofire'
  pod 'SwiftyJSON'
  pod 'HandyJSON'
  # Pods for news_eve
end

最後


上面步驟只需要點擊 App 中的按鈕,早報新聞就複製到系統剪切板了,接着可以轉發到多個微信群了


當然,最後一步也可以利用 SoloPi 或者無障礙,將內容利用自動化操作,一鍵轉發出去


我已經將文中部分源碼上傳到 公眾號 後台,關注公眾號 AirPython 后回復「 早報 」即可獲得全部源碼


如果你覺得文章還不錯,請大家點贊分享下。你的肯定是我最大的鼓勵和支持。


本站聲明:網站內容來源於博客園,如有侵權,請聯繫我們,我們將及時處理

台中搬家公司費用怎麼算?



擁有20年純熟搬遷經驗,提供免費估價且流程透明更是5星評價的搬家公司





Orignal From: 如何利用 Python 爬蟲實現給微信群發新聞早報?(詳細)_台中搬家

留言

這個網誌中的熱門文章

有了四步解題法模板,再也不害怕動態規劃!(看不懂算我輸)

導言 動態規劃問題一直是算法面試當中的重點和難點,並且動態規劃這種通過空間換取時間的算法思想在實際的工作中也會被頻繁用到,這篇文章的目的主要是解釋清楚 什麼是動態規劃 ,還有就是面對一道動態規劃問題,一般的 思考步驟 以及其中的注意事項等等,最後通過幾道題目將理論和實踐結合。 什麼是動態規劃 如果你還沒有聽說過動態規劃,或者僅僅只有耳聞,或許你可以看看 Quora 上面的這個 回答 。 How to explain dynamic 用一句話解釋動態規劃就是 " 記住你之前做過的事 ",如果更準確些,其實是 " 記住你之前得到的答案 "。 我舉個大家工作中經常遇到的例子。 在軟件開發中,大家經常會遇到一些系統配置的問題,配置不對,系統就會報錯,這個時候一般都會去 Google 或者是查閱相關的文檔,花了一定的時間將配置修改好。 過了一段時間,去到另一個系統,遇到類似的問題,這個時候已經記不清之前修改過的配置文件長什麼樣,這個時候有兩種方案,一種方案還是去 Google 或者查閱文檔,另一種方案是借鑒之前修改過的配置,第一種做法其實是萬金油,因為你遇到的任何問題其實都可以去 Google,去查閱相關文件找答案,但是這會花費一定的時間,相比之下,第二種方案肯定會更加地節約時間,但是這個方案是有條件的,條件如下: 之前的問題和當前的問題有着關聯性,換句話說,之前問題得到的答案可以幫助解決當前問題 需要記錄之前問題的答案 當然在這個例子中,可以看到的是,上面這兩個條件均滿足,大可去到之前配置過的文件中,將配置拷貝過來,然後做些細微的調整即可解決當前問題,節約了大量的時間。 不知道你是否從這些描述中發現,對於一個動態規劃問題,我們只需要從兩個方面考慮,那就是 找出問題之間的聯繫 ,以及 記錄答案 ,這裏的難點其實是找出問題之間的聯繫,記錄答案只是順帶的事情,利用一些簡單的數據結構就可以做到。 概念 上面的解釋如果大家可以理解的話,接    動態規劃 算法是通過拆分問題,定義問題狀態和狀態之間的關係,使得問題能夠以遞推(或者說分治)的方式去解決。它的幾個重要概念如下所述。    階段: 對於一個完整的問題過程,適當的切分為若干個相互聯繫的子問題,每次在求解一個子問題...

純電動 Mini Cooper SE 將成為中國國產車,年產 16 萬輛

BMW 集團與中國長城汽車合資,將於江蘇建立新廠,專門投入生產 MINI Cooper SE 和部分長城品牌電動車,預計於 2022 年完工並投入生產,每年將可生產 16 萬輛電動車。 靈動可愛的 Mini Cooper,在許多車迷心中都有著特殊的地位,今年 7 月發表了首款純電動版本的 Mini Cooper SE 之後,獲得熱烈迴響,預訂數量已接近 8 萬台,顯示大家對於純電 Mini 的熱愛,因為油電版的 Mini Cooper Countryman 的全球總銷售量也才 3 萬出頭。 Mini Cooper SE 之前公布了官方定價,最低從 27,900 歐元起算,美國售價約 29,900 美元。相比現有的三門款,只貴了一成左右。然而,三年後,中國消費者將有機會買到最便宜的電動 Mini。 電動 Mini Cooper SE 最低價是 27,900 歐元,扣掉全額補助最低可以到 24,400 歐元。 BMW 集團與中國長城汽車集團於 2018 年宣布,將組建合資公司光束汽車,投入在中國的電動車生產計畫,而現在他們正式宣布啟動計畫,於江蘇張家港打造一個新工廠,全部投入電動車的製造,包括了 Mini Cooper SE 和其他長城汽車旗下的電動車。 目前的電動 Mini 只在英國牛津工廠製造,不難想像當產能轉移到中國後,Mini Cooper SE 的價格將有機會進一步調降,來競爭全球最大的電動車市場。這座屬於合資公司光束汽車的新工廠,採用一個新的產銷模式,由 BMW 和長城共同合作開發、設計、製造新產品,但是銷售通路完全沿用原本的品牌渠道。 換句話說,2020 年到 2022 年銷售的電動 Mini,將會是英國製造,而 2022 年後就會有中國製造版本開賣,考量到 Mini 在中國每年約有 30 萬輛的銷售額,同時油電版的 Coutryman 銷量更佔了全球將近五分之一,無怪乎 BMW 會想在最接近主要市場的地方蓋工廠囉。 外型完美復刻油車版 最後,簡單介紹一下 Mini Cooper SE 這台車。Mini 在電動化的路上,盡力保持著跟經典造型一致的設計,畢竟大家愛的就是它的設計。電動版的 Mini 車頭、車身跟車屁股都多了一個黃色的插頭標誌,車頭的氣壩則變成封閉式設計,除此之外,幾乎看不出來差別,連馬達...

我的USB為什麼總是無法識別,到底是為甚麼呢?這真的讓我好困擾

其實判斷軟件硬件問題很簡單,在別的機器或換個系統試試就可以了.有些小的問題不妨先用專門軟件格式化下.還有提醒你WINDOWS下格式化時要選擇FAT,不要選FAT32。 倘若插入後,在右下角彈出電腦正在嘗試連接此USB設備的一些信息,有時會彈出對話框讓用戶選擇,有些用戶還沒看清就點了否,或者因為電腦一些初始的設置問題,禁止了USB的一些功能。解決辦法:右鍵點"我的電腦",選"屬性"--"硬件"--"驅動器簽名",在此選擇"忽略",點"確定"。然後重新插上usb,還是不連的話,再右鍵點"我的電腦"--"屬性"--"硬件"--"設備管理器",從中找到"通用串行總線控制器",右鍵,然後"掃描檢測硬件改動"。如果都不行那就是USB識別程序或U盤的問題從控制面板進入添加或刪除硬件將所有USB設備都刪除,重新安裝需要使用的USB設備驅動程序,重新啟動電腦 USB CONNECTOR   USB CONNECTOR  USB CONNECTOR Orignal From: 我的USB為什麼總是無法識別,到底是為甚麼呢?這真的讓我好困擾