欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python連接、操作mongodb數(shù)據(jù)庫的方法實(shí)例詳解

 更新時(shí)間:2019年09月11日 08:45:19   作者:陽望  
這篇文章主要介紹了python連接、操作mongodb數(shù)據(jù)庫的方法,結(jié)合實(shí)例形式詳細(xì)分析了Python針對(duì)MongoDB數(shù)據(jù)庫的連接、查詢、排序等相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了python連接、操作mongodb數(shù)據(jù)庫的方法。分享給大家供大家參考,具體如下:

數(shù)據(jù)庫連接

from pymongo import MongoClient
import pandas as pd
#建立MongoDB數(shù)據(jù)庫連接
client = MongoClient('162.23.167.36',27101)#或MongoClient("mongodb://162.23.167.36:27101/")
#連接所需數(shù)據(jù)庫,testDatabase為數(shù)據(jù)庫名:
db=client.testDatabase
#連接所用集合,也就是我們通常所說的表,testTable為表名
collection=db.testTable

查詢前幾條

dataSet=collection.find().limit(3)
for item in dataSet:
  print(item)

無條件查詢?nèi)?/strong>

dataSet=collection.find()
for item in dataSet:
  print(item)

按AND條件查詢?nèi)?/strong>

#查詢cpu使用率大于等于10且內(nèi)存使用率大于等于10的所有字段數(shù)據(jù)
dataSet=collection.find({"cpu":{"$gte":10},"mem":{"$gte":10}})
for item in dataSet:
  print(item)

按AND條件查詢指定字段數(shù)據(jù)

#查詢cpu使用率大于等于10且內(nèi)存使用率大于等于10的數(shù)據(jù),字段只顯示did、ts、cpu、mem
dataSet=collection.find({"cpu":{"$gte":10},"mem":{"$gte":10}}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)
#查詢cpu使用率等于0且內(nèi)存使用率等于0的數(shù)據(jù),字段只顯示did、ts、cpu、mem
dataSet=collection.find({"cpu":0,"mem":0}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)

按OR條件查詢指定字段數(shù)據(jù)

#查詢cpu使用率大于等于10或者內(nèi)存使用率大于等于10的數(shù)據(jù),字段只顯示did、ts、cpu、mem
dataSet=collection.find({"$or":[{"cpu":{"$gte":10}},{"mem":{"$gte":10}}]}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)
#查詢cpu使用率等于10或者內(nèi)存使用率等于10的數(shù)據(jù),字段只顯示did、ts、cpu、mem
dataSet=collection.find({"$or":[{"cpu":10},{"mem":10}]}, {"did":1,"ts":1,"cpu":1,"mem":1})
for item in dataSet:
  print(item)

mongodb的條件操作符

#  > - $gt
#  < - $lt
#  >= - $gte
#  <= - $lte

排序

#單列升序排序查詢,,1 為升序,-1為降序
dataSet=collection.find().sort([("cpu",1)])
for item in dataSet:
  print(item)
#多列排序查詢
dataSet=collection.find().sort([('did',pymongo.ASCENDING),('cpu',pymongo.DESCENDING)])
for item in dataSet:
  print(item)

查詢結(jié)果寫入excel

#查詢cpu使用率大于等于10且內(nèi)存使用率大于等于10的數(shù)據(jù),字段只顯示did、ts、cpu、mem,查詢結(jié)果寫入excel
import pandas as pd
dataSet=collection.find({"cpu":{"$gte":10},"mem":{"$gte":10}}, {"did":1,"ts":1,"cpu":1,"mem":1})
did,ts,cpu,mem=[],[],[],[]
for item in dataSet:
  did.append(item["did"])
  ts.append(item["ts"])
  cpu.append(item["cpu"])
  mem.append(item["mem"])
df=pd.DataFrame({"did":did,"ts":ts,"cpu":cpu,"mem":mem})
df.to_excel("C:/Users/Desktop/設(shè)備cpu內(nèi)存數(shù)據(jù).xlsx")

跳行查詢

#下面表示跳過兩條數(shù)據(jù)后讀取數(shù)據(jù)
dataSet=collection.find().skip(2)
for item in dataSet:
  print(item)

去重

#查詢cpu使用率大于20、did不重復(fù)的數(shù)據(jù)
dataSet=collection.distinct("did",{"cpu":{$gt:20}})
for item in dataSet:
  print(item)
#等同mysql的select distinct(did) from user where cpu>20

參考:

操作mongodb更詳細(xì)說明http://www.dbjr.com.cn/article/169726.htm

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python常見數(shù)據(jù)庫操作技巧匯總》、《Python數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Python模塊學(xué)習(xí) filecmp 文件比較

    Python模塊學(xué)習(xí) filecmp 文件比較

    filecmp模塊用于比較文件及文件夾的內(nèi)容,它是一個(gè)輕量級(jí)的工具,使用非常簡單。python標(biāo)準(zhǔn)庫還提供了difflib模塊用于比較文件的內(nèi)容。關(guān)于difflib模塊,且聽下回分解
    2012-08-08
  • 如何用VScode配置Python開發(fā)環(huán)境

    如何用VScode配置Python開發(fā)環(huán)境

    這篇文章主要介紹了如何用VScode配置Python開發(fā)環(huán)境,vscode有很多優(yōu)點(diǎn),用VScode來編寫Python,也是相當(dāng)?shù)暮糜玫?需要的朋友可以參考下
    2023-03-03
  • 寶塔部署django項(xiàng)目的實(shí)現(xiàn)步驟(圖文教程)

    寶塔部署django項(xiàng)目的實(shí)現(xiàn)步驟(圖文教程)

    本文主要介紹了寶塔部署django項(xiàng)目的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Python自定義函數(shù)的創(chuàng)建、調(diào)用和函數(shù)的參數(shù)詳解

    Python自定義函數(shù)的創(chuàng)建、調(diào)用和函數(shù)的參數(shù)詳解

    這篇文章主要介紹了Python自定義函數(shù)的創(chuàng)建、調(diào)用和函數(shù)的參數(shù)、變量作用域等常見問題,需要的朋友可以參考下
    2014-03-03
  • Python tkinter界面實(shí)現(xiàn)歷史天氣查詢的示例代碼

    Python tkinter界面實(shí)現(xiàn)歷史天氣查詢的示例代碼

    這篇文章主要介紹了Python tkinter界面實(shí)現(xiàn)歷史天氣查詢的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 關(guān)于Python 常用獲取元素 Driver 總結(jié)

    關(guān)于Python 常用獲取元素 Driver 總結(jié)

    今天小編就為大家分享一篇關(guān)于Python 常用獲取元素 Driver 總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 淺談Python3中datetime不同時(shí)區(qū)轉(zhuǎn)換介紹與踩坑

    淺談Python3中datetime不同時(shí)區(qū)轉(zhuǎn)換介紹與踩坑

    最近的項(xiàng)目需要根據(jù)用戶所屬時(shí)區(qū)制定一些特定策略,學(xué)習(xí)、應(yīng)用了若干python3的時(shí)區(qū)轉(zhuǎn)換相關(guān)知識(shí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • python 生成圖形驗(yàn)證碼的方法示例

    python 生成圖形驗(yàn)證碼的方法示例

    日常在網(wǎng)站使用過程中經(jīng)常遇到圖形驗(yàn)證,這篇文章主要介紹了python 生成圖形驗(yàn)證碼的方法示例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-11-11
  • 解決Django后臺(tái)ManyToManyField顯示成Object的問題

    解決Django后臺(tái)ManyToManyField顯示成Object的問題

    今天小編就為大家分享一篇解決Django后臺(tái)ManyToManyField顯示成Object的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • zip在python中的用法小結(jié)

    zip在python中的用法小結(jié)

    Python中的zip函數(shù)是一個(gè)非常有用的工具,可以幫助我們同時(shí)處理多個(gè)可迭代對(duì)象,通過使用zip函數(shù),我們可以將多個(gè)列表或迭代器中的元素打包成一個(gè)個(gè)元組,然后返回由這些元組組成的列表,這篇文章介紹zip在python中的用法,感興趣的朋友一起看看吧
    2024-02-02

最新評(píng)論