1术幔、蘇寧百萬級商品爬取 思路講解 類別爬取

蘇寧類別面 https://list.suning.com/

解析圖.png

通過圖可知另萤,總共有N個類別,每個類別都是一個DIV區(qū)塊诅挑,然后再繼續(xù)分解DIV區(qū)塊分析內(nèi)容四敞。我們要得到的是類別表,據(jù)圖所示我們可以分析得出類別表的結(jié)構(gòu)應(yīng)當樹形的拔妥。所以涉及的表應(yīng)該是包含子節(jié)點和父節(jié)點的忿危。初步設(shè)計圖如下

Id Pid Code Name Url
主鍵 父節(jié)點 編碼 名稱 地址
解析圖2.png

我們可以得到解析圖2對應(yīng)的 Xpath為://*[@id="20089"]/div[2]/div[2] ∶涣可是因為是通過ID作為唯一Key來向下找铺厨,所以我們需要先得到所有的Key值。這個方法被我放棄而選用了另外一種方式硬纤。

/html/body/div[5]/div[2].首先找到如果所示xpath對應(yīng)的內(nèi)容

/html/body/div[5]/div[2].png

那么如果我們想要得到下屬的內(nèi)容只需要增加一個后綴
/html/body/div[5]/div[2]/div
此時我們得到了所有模塊的內(nèi)容解滓,那么我們接下去分析

一級.png

二級+三級.png

還是以“手機配件”為例。一級類別筝家,二級類別伐蒂、三級類別如果所示。我們又如何得到內(nèi)容肛鹏,然后將其變成單元行的形式插入數(shù)據(jù)庫中呢逸邦?

解決方案如下
根據(jù)網(wǎng)頁內(nèi)容可知,一級類別包含著二級類別在扰,二級類別包含著三級類別缕减。所以我們可以采用如下方式。
首先獲取所有一級類別芒珠,即解析圖2.png所示內(nèi)容桥狡。
一級類別 A方法
循環(huán)當前內(nèi)容
1、解析內(nèi)容 增加當前A級類別實體
2、循環(huán)包含的二級內(nèi)容裹芝,處理
3部逮、合并實體
二級類別 B方法
循環(huán)當前內(nèi)容
1、解析內(nèi)容 增加當前B級類別實體
2嫂易、循環(huán)包含的三級級內(nèi)容兄朋,處理
3、返回實體給A方法
三級類別 C方法
循環(huán)當前內(nèi)容
1怜械、解析內(nèi)容 增加當前C級類別實體
2颅和、返回實體給B方法

ABC.png


代碼講解

ABC(Combine)方法
遍歷InitA方法獲取的內(nèi)容,增加A實體后將ANode作為參數(shù)傳遞給InitB方法缕允。依次類推峡扩,最后得到符合要求的實體。

    private static List<POCO_Category> CombineA_B_C()
        {
            List<POCO_Category> AList = new List<POCO_Category>();

            int idIndex = 1;
            foreach (HtmlNode xNode in InitA())
            {
                POCO_Category aModel = new POCO_Category()
                {
                    Id = ToLevelCode(idIndex),
                    PId = "000",
                    Levels = 1,
                    Code = ToLevelCode(idIndex),
                    Name = xNode.SelectSingleNode("./h2").InnerText
                };
                AList.Add(aModel);

                var blist = InitB(aModel, xNode);
                AList.AddRange(blist);
                idIndex = idIndex + blist.Count + 1;
            }

            return AList;
        }

        private static List<HtmlNode> InitA()
        {
            var url = "https://list.suning.com/#20089";
            var web = new HtmlWeb();
            var docWeb = web.Load(url);
            //var cssNodes = docWeb.DocumentNode.CssSelect(".search-main.introduce.clearfix > div").ToList();//147毫秒
            List<HtmlNode> xpathNodes = docWeb.DocumentNode.SelectNodes("/html/body/div[5]/div[2]/div").ToList();
            return xpathNodes;
        }

        private static List<POCO_Category> InitB(POCO_Category parentModel, HtmlNode node)
        {
            int idIndex = Convert.ToInt32(parentModel.Id) + 1;
            List<POCO_Category> bList = new List<POCO_Category>();

            var xNodes = node.SelectNodes("./div").ToList();
            foreach (var xNode in xNodes)
            {
                var cateModel = xNode.SelectSingleNode("./div[1]/a");
                POCO_Category bModel = new POCO_Category()
                {
                    Id = ToLevelCode(idIndex),
                    PId = parentModel.Id,
                    Code = $"{parentModel.Code}_{ToLevelCode(idIndex)}",
                    Name = cateModel.InnerText,
                    Url = $"https:{cateModel.GetAttributeValue("href")}",
                    Levels = 2
                };
                bList.Add(bModel);

                var clist = InitC(bModel, xNode.SelectSingleNode("./div[2]"));
                bList.AddRange(clist);
                idIndex = idIndex + clist.Count + 1;
            }

            return bList;
        }

        private static List<POCO_Category> InitC(POCO_Category parentModel, HtmlNode node)
        {
            int idIndex = Convert.ToInt32(parentModel.Id) + 1;
            List<POCO_Category> cList = new List<POCO_Category>();

            HtmlNodeCollection xNodes = node.SelectNodes("./a");

            if (xNodes != null && xNodes.Count > 0)
            {
                foreach (var xNode in xNodes)
                {
                    POCO_Category cModel = new POCO_Category()
                    {
                        Id = ToLevelCode(idIndex),
                        PId = parentModel.Id,
                        Code = $"{parentModel.Code}_{ToLevelCode(idIndex)}",
                        Name = xNode.InnerText,
                        Url = $"https:{xNode.GetAttributeValue("href")}",
                        Levels = 3
                    };
                    cList.Add(cModel);
                    idIndex += 1;
                }
            }

            return cList;
        }

        private static string ToLevelCode(int index)
        {
            return index.ToString("000");
        }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末障本,一起剝皮案震驚了整個濱河市教届,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌驾霜,老刑警劉巖巍佑,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異寄悯,居然都是意外死亡萤衰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門猜旬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來脆栋,“玉大人,你說我怎么就攤上這事洒擦〈徽” “怎么了?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵熟嫩,是天一觀的道長秦踪。 經(jīng)常有香客問我,道長掸茅,這世上最難降的妖魔是什么椅邓? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮昧狮,結(jié)果婚禮上景馁,老公的妹妹穿的比我還像新娘。我一直安慰自己逗鸣,他們只是感情好合住,可當我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布绰精。 她就那樣靜靜地躺著,像睡著了一般透葛。 火紅的嫁衣襯著肌膚如雪笨使。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天僚害,我揣著相機與錄音硫椰,去河邊找鬼。 笑死贡珊,一個胖子當著我的面吹牛最爬,可吹牛的內(nèi)容都是我干的涉馁。 我是一名探鬼主播门岔,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼烤送!你這毒婦竟也來了寒随?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤帮坚,失蹤者是張志新(化名)和其女友劉穎妻往,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體试和,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡讯泣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了阅悍。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片好渠。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖节视,靈堂內(nèi)的尸體忽然破棺而出拳锚,到底是詐尸還是另有隱情,我是刑警寧澤寻行,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布霍掺,位于F島的核電站,受9級特大地震影響拌蜘,放射性物質(zhì)發(fā)生泄漏杆烁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一简卧、第九天 我趴在偏房一處隱蔽的房頂上張望连躏。 院中可真熱鬧,春花似錦贞滨、人聲如沸入热。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽勺良。三九已至绰播,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間尚困,已是汗流浹背蠢箩。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留事甜,地道東北人谬泌。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像逻谦,于是被迫代替她去往敵國和親掌实。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容