Python爬虫从入门到实战
系统学习网络爬虫技术,掌握 requests、BeautifulSoup、Selenium 等核心工具
html { scroll-behavior: smooth; } body { font-family: "Noto Sans SC", "PingFang SC", "Microsoft YaHei", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; max-width: 1100px; margin: 0 auto; padding: 0 32px; line-height: 1.8; background: var(--bg); color: var(--text-primary); font-size: 16px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } /* Header */ header { display: flex; justify-content: space-between; align-items: center; padding: 32px 0; margin-bottom: 48px; border-bottom: 1px solid var(--border-color); } .logo { display: flex; align-items: center; gap: 16px; font-size: 18px; font-weight: 600; color: var(--primary); text-decoration: none; letter-spacing: -0.3px; } .logo-mark { width: 36px; height: 36px; background: var(--primary); border-radius: 6px; display: flex; align-items: center; justify-content: center; color: #fff; font-family: "JetBrains Mono", "Fira Code", monospace; font-size: 14px; font-weight: 600; letter-spacing: -0.5px; } .nav { display: flex; gap: 4px; } .nav a { color: var(--text-secondary); text-decoration: none; padding: 10px 20px; font-size: 14px; font-weight: 500; transition: color 0.2s ease; } .nav a:hover, .nav a.active { color: var(--primary); } /* Page Header */ .page-header { text-align: left; padding: 48px 0; margin-bottom: 40px; } .page-header h1 { font-size: 36px; margin-bottom: 16px; font-weight: 700; letter-spacing: -1px; color: var(--primary); } .page-header p { font-size: 16px; color: var(--text-secondary); max-width: 600px; line-height: 1.8; } /* Series Nav */ .series-nav { display: flex; gap: 8px; margin-bottom: 48px; flex-wrap: wrap; } .series-nav-item { display: flex; align-items: center; gap: 6px; padding: 10px 20px; background: var(--card-bg); border-radius: 4px; text-decoration: none; color: var(--text-secondary); font-weight: 500; font-size: 13px; border: 1px solid var(--border-color); transition: all 0.2s ease; } .series-nav-item:hover, .series-nav-item.active { border-color: var(--primary); color: var(--primary); } /* Series Section */ .series-section { margin-bottom: 64px; } .series-header { display: flex; align-items: center; gap: 16px; margin-bottom: 24px; padding-bottom: 16px; border-bottom: 1px solid var(--border-color); } .series-icon { width: 48px; height: 48px; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 16px; font-weight: 700; background: var(--bg); border: 1px solid var(--border-color); } .series-title h2 { font-size: 20px; margin-bottom: 4px; font-weight: 600; letter-spacing: -0.3px; } .series-title p { color: var(--text-tertiary); font-size: 13px; } .series-count { margin-left: auto; background: var(--bg); padding: 6px 14px; border-radius: 4px; font-size: 12px; color: var(--text-secondary); border: 1px solid var(--border-color); font-weight: 500; } /* Series Articles */ .series-articles { display: grid; gap: 12px; } .series-article { background: var(--card-bg); padding: 20px 24px; border-radius: 6px; display: flex; align-items: center; gap: 20px; text-decoration: none; color: var(--primary); border: 1px solid var(--border-color); transition: border-color 0.2s ease; } .series-article:hover { border-color: #d1d5db; } .article-number { width: 40px; height: 40px; border-radius: 4px; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 16px; flex-shrink: 0; background: var(--bg); border: 1px solid var(--border-color); } .article-content { flex-grow: 1; } .article-content h3 { font-size: 15px; margin-bottom: 4px; font-weight: 600; letter-spacing: -0.1px; } .article-content p { color: var(--text-secondary); font-size: 13px; line-height: 1.6; } .article-meta { display: flex; gap: 16px; color: var(--text-tertiary); font-size: 12px; } .article-tags { display: flex; gap: 6px; } .article-tag { background: var(--bg); padding: 3px 10px; border-radius: 4px; font-size: 11px; color: var(--text-secondary); font-weight: 500; } /* Learning Path */ .learning-path { background: var(--card-bg); border-radius: 8px; padding: 40px; margin: 56px 0; border: 1px solid var(--border-color); } .learning-path h3 { font-size: 18px; margin-bottom: 24px; text-align: left; font-weight: 600; } .path-nodes { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 16px 0; } .path-nodes::before { content: ''; position: absolute; left: 0; right: 0; height: 2px; background: var(--border-color); z-index: 0; } .path-node { width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 700; position: relative; z-index: 1; background: var(--card-bg); border: 2px solid var(--border-color); } .path-node.active { background: var(--primary); border-color: var(--primary); color: #fff; } .path-label { position: absolute; top: 64px; left: 50%; transform: translateX(-50%); white-space: nowrap; font-size: 12px; color: var(--text-secondary); font-weight: 500; } /* Footer */ footer { text-align: center; padding: 48px 24px 32px; margin-top: 56px; color: var(--text-secondary); border-top: 1px solid var(--border-color); } .footer-links { display: flex; justify-content: center; gap: 28px; margin-bottom: 24px; } .footer-links a { color: var(--text-secondary); text-decoration: none; font-size: 13px; transition: color 0.2s ease; } .footer-links a:hover { color: var(--primary); } footer p { font-size: 13px; color: var(--text-tertiary); } /* Responsive */ @media (max-width: 900px) { .series-article { flex-direction: column; text-align: left; align-items: flex-start; } .article-tags { margin-left: 0; margin-top: 12px; } .path-nodes { flex-wrap: wrap; gap: 24px; justify-content: center; } .nav { flex-wrap: wrap; gap: 2px; } } @media (max-width: 640px) { header { flex-direction: column; gap: 20px; } .nav { gap: 2px; } .nav a { padding: 8px 12px; font-size: 13px; } .page-header h1 { font-size: 28px; } .series-nav { gap: 6px; } .series-header { flex-direction: column; text-align: left; align-items: flex-start; } .series-count { margin-left: 0; margin-top: 8px; } } /* Scrollbar */ ::-webkit-scrollbar { width: 6px; } ::-webkit-scrollbar-track { background: transparent; } ::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 3px; } ::-webkit-scrollbar-thumb:hover { background: #9ca3af; }
系统化的技术学习路径,让你的学习更有方向。这里按照主题将文章进行分类整理,形成完整的知识体系。
从入门到精通,掌握 Python 开发的核心技能
构建现代化的高性能 Web 应用
用数据说话,让分析更有说服力
从开发到生产,掌握 DevOps 全流程