Python中如何將爬取到的數據循環存入到csv文件中?
問題描述
求大神指導 再此感激不盡?。?!
我想要把輸出的結果存入到csv文件中
我的代碼如下:(Python 需要3.5版本的)
# coding:utf-8import requestsimport jsonimport timetime_unix = time.time()time_unix = str(time_unix).split(’.’)[0]headers = { ’Host’: ’sec.wedengta.com’, ’User-Agent’: ’Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.113 Safari/537.36’, ’Connection’: ’keep-alive’, ’Content-Language’: ’zh-CN,zh;q=0.8’, ’Accept’: ’application / json’, # ’Accept-Language’: ’ zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3’, ’X-Requested-With’: ’XMLHttpRequest’, ’Referer’: ’https://sec.wedengta.com/findPool.html?dt_from=web&title=%E8%85%BE%E8%AE%AF%E6%B6%A8%E5%81%9C%E6%9D%BF%E9%A2%84%E6%B5%8B%20-%20%E5%8E%86%E5%8F%B2%E6%8E%A8%E8%8D%90&id=99970_56&webviewType=userActivitesType&dt_page_type=11&timeStamp=1488801827765&barType=null&accessp=null’, ’Accept-Encoding’: ’gzip, deflate, br’ }url = ’https://sec.wedengta.com/getIntelliStock?action=IntelliSecPool&id=99970_56&_={0}’.format(time_unix)request = requests.get(url, headers=headers)temp = str(json.loads(request.text)).replace(’’, ’’)dic = eval(temp)content = dic[’content’]content = eval(content)vtDaySec = content[’vtDaySec’]for every in vtDaySec: for every_company in every[’vtSec’]:print(every[’sOptime’])print(every_company[’sChnName’])print(every_company[’sDtCode’][4:])print(’n’)
運行出來結果截圖:
我想要的結果是:
問題解答
回答1:#coding=utf-8import requestsimport jsonimport timeimport csvimport codecsheaders = { ’User-Agent’: ’Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.113 Safari/537.36’}url = ’https://sec.wedengta.com/getIntelliStock?action=IntelliSecPool&id=99970_56&_={0}’.format(time.time())r = requests.get(url, headers=headers)result = json.loads(r.text)rows = []for every in json.loads(result[’content’])[’vtDaySec’]: for company in every[’vtSec’]:row = ( every[’sOptime’].encode(’utf-8’), company[’sChnName’].encode(’utf-8’), company[’sDtCode’][4:].encode(’utf-8’))rows.append(row)with codecs.open(’company.csv’, ’wb’) as f: f.write(codecs.BOM_UTF8) writer = csv.writer(f) writer.writerow([’date’, ’stk_name’, ’stk_num’]) writer.writerows(rows)回答2:
csv = open(’data.csv’, ’w’)for every in vtDaySec: for every_company in every[’vtSec’]:csv.write(’,’.join([every[’sOptime’], every_company[’sChnName’], every_company[’sDtCode’][4:]]) + ’n’)csv.close()
相關文章:
1. mysql優化 - mysql count(id)查詢速度如何優化?2. mysql主從 - 請教下mysql 主動-被動模式的雙主配置 和 主從配置在應用上有什么區別?3. angular.js - angularjs 用ng-reapt渲染的dom 怎么獲取上面的屬性4. 主從備份 - 跪求mysql 高可用主從方案5. css3 - [CSS] 動畫效果 3D翻轉bug6. node.js - node_moduls太多了7. angular.js - Angular路由和express路由的組合使用問題8. python如何不改動文件的情況下修改文件的 修改日期9. python - django 里自定義的 login 方法,如何使用 login_required()10. angular.js - 不適用其他構建工具,怎么搭建angular1項目
![css3 - [CSS] 動畫效果 3D翻轉bug](http://www.aoyou183.cn/attached/image/news/202304/110831f073.png)