localhost 已拒絕連接_【Python】MongoDB數據庫的連接和操作

606c6525debadcfe451ebcdbc474da16.gif

安裝

Python 要連接 MongoDB 需要 MongoDB 驅動。

pip安裝:

python3 -m pip3 install?pymongo

創建數據庫

import?pymongo
?
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["loaderman"]

注意: 在 MongoDB 中,數據庫只有在內容插入后才會創建! 就是說,數據庫創建后要創建集合(數據表)并插入一個文檔(記錄),數據庫才會真正創建。

判斷數據庫是否已存在:

import?pymongo
?
myclient = pymongo.MongoClient('mongodb://localhost:27017/')
?
dblist = myclient.list_database_names()
# dblist = myclient.database_names()
if?"loaderman"?in?dblist:
??print("數據庫已存在!")

注意:database_names 在最新版本的 Python 中已廢棄,Python3.7+ 之后的版本改為了 list_database_names()。

創建集合

import?pymongo
?
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["loaderman"]
?
mycol = mydb["t_user"]
import?pymongo
?
myclient = pymongo.MongoClient('mongodb://localhost:27017/')
?
mydb = myclient['loaderman']
?
collist = mydb. list_collection_names()
# collist = mydb.collection_names()
if?"t_user"?in?collist: # 判斷 sites 集合是否存在
??print("集合已存在!")

插入數據

用 insert_one() 方法,該方法的第一參數是字典 name => value 對。

插入單個數據:

import?pymongo


def?main():
????myclient = pymongo.MongoClient('mongodb://localhost:27017/')
????mydb = myclient["loaderman"]
????mycol = mydb["t_user"]
????mydict = {"name": "loaderman", "age": "18", "des": "碼上加油站,一起來加油"}
????x = mycol.insert_one(mydict)
????print(x.inserted_id)

if?__name__ == "__main__":
????main()

輸出:

5f05c019381b3ce588e04696

效果:

620213b1e62ea4fa1c800b780cb6c488.png

插入多條數據:

插入多個文檔使用 insert_many() 方法,該方法的第一參數是字典列表。

import?pymongo


def?main():
????myclient = pymongo.MongoClient('mongodb://localhost:27017/')
????mydb = myclient["loaderman"]
????mycol = mydb["t_site"]
????mylist = [
????????{"name": "Taobao", "alexa": "100", "url": "https://www.taobao.com"},
????????{"name": "QQ", "alexa": "101", "url": "https://www.qq.com"},
????????{"name": "Facebook", "alexa": "10", "url": "https://www.facebook.com"},
????????{"name": "知乎", "alexa": "103", "url": "https://www.zhihu.com"},
????????{"name": "Github", "alexa": "109", "url": "https://www.github.com"}
????]

????x = mycol.insert_many(mylist)

????# 輸出插入的所有文檔對應的 _id 值
????print(x.inserted_ids)


if?__name__ == "__main__":
????main()

輸出:

[ObjectId('5f05c0c0bacd4ef964560988'), ObjectId('5f05c0c0bacd4ef964560989'), ObjectId('5f05c0c0bacd4ef96456098a'), ObjectId('5f05c0c0bacd4ef96456098b'), ObjectId('5f05c0c0bacd4ef96456098c')]

效果:

bb10bd153252631e6bb5fe386d0310fa.png

查詢數據

  • 使用 find_one() 方法來查詢集合中的一條數據。

  • find() 方法可以查詢集合中的所有數據,類似 SQL 中的 SELECT * 操作。使用 find() 方法來查詢指定字段的數據,將要返回的字段對應值設置為 1。 可以對find() 中設置參數來過濾數據。

  • 如果我們要對查詢結果設置指定條數的記錄可以使用 limit() 方法,該方法只接受一個數字參數。

import?pymongo


def?main():
????myclient = pymongo.MongoClient('mongodb://localhost:27017/')
????mydb = myclient["loaderman"]
????mycol = mydb["t_site"]
????# 使用 find_one() 方法來查詢集合中的一條數據。
????x = mycol.find_one()
????print("***********查詢集合中的一條數據。************")
????print(x)
????print("***********查詢集合中的所有數據************")
????# find() 方法可以查詢集合中的所有數據,類似 SQL 中的 SELECT * 操作。
????for?x in?mycol.find():
????????print(x)
????print("***********除了 alexa 字段外,其他都返回************")
????# find() 方法來查詢指定字段的數據,將要返回的字段對應值設置為 1。
????for?x in?mycol.find({}, {"alexa": 0}):
????????print(x)
????# 根據指定條件查詢,查找 name 字段為 "QQ" 的數據:
????myquery = {"name": "QQ"}
????mydoc = mycol.find(myquery)
????print("***********根據指定條件查詢************")
????for?x in?mydoc:
????????print(x)
????# 讀取 name 字段中第一個字母 ASCII 值大于 H" 的數據
????myquery2 = {"name": {"$gt": "H"}}
????mydoc2 = mycol.find(myquery2)
????print("***********讀取 name 字段中第一個字母ASCII值大于H的數據************")
????for?x in?mydoc2:
????????print(x)

????# 正則表達式查詢,讀取 name 字段中第一個字母為 "R" 的數據,正則表達式修飾符條件為 {"$regex": "^R"}
????myquery = {"name": {"$regex": "Q"}}
????print("***********正則表達式查詢************")
????mydoc = mycol.find(myquery)
????for?x in?mydoc:
????????print(x)
????print("***********返回指定條數記錄3條數據************")
????# 返回指定條數記錄,查詢結果設置指定條數的記錄可以使用 limit() 方法,該方法只接受一個數字參數。
????myresult = mycol.find().limit(3)
????# 輸出結果
????for?x in?myresult:
????????print(x)


if?__name__ == "__main__":
????main()

運行輸出:

***********查詢集合中的一條數據。************
{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'alexa': '100', 'url': 'https://www.taobao.com'}
***********查詢集合中的所有數據************
{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'alexa': '100', 'url': 'https://www.taobao.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c494'), 'name': 'Facebook', 'alexa': '10', 'url': 'https://www.facebook.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c495'), 'name': '知乎', 'alexa': '103', 'url': 'https://www.zhihu.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c496'), 'name': 'Github', 'alexa': '109', 'url': 'https://www.github.com'}
***********除了 alexa 字段外,其他都返回************
{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'url': 'https://www.taobao.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c494'), 'name': 'Facebook', 'url': 'https://www.facebook.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c495'), 'name': '知乎', 'url': 'https://www.zhihu.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c496'), 'name': 'Github', 'url': 'https://www.github.com'}
***********根據指定條件查詢************
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
***********讀取 name 字段中第一個字母ASCII值大于H的數據************
{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'alexa': '100', 'url': 'https://www.taobao.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c495'), 'name': '知乎', 'alexa': '103', 'url': 'https://www.zhihu.com'}
***********正則表達式查詢************
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
***********返回指定條數記錄3條數據************
{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'alexa': '100', 'url': 'https://www.taobao.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c494'), 'name': 'Facebook', 'alexa': '10', 'url': 'https://www.facebook.com'}

更新數據

import?pymongo


def?main():
????myclient = pymongo.MongoClient('mongodb://localhost:27017/')
????mydb = myclient["loaderman"]
????mycol = mydb["t_site"]
????myquery = {"alexa": "100"}
????newvalues = {"$set": {"alexa": "12345"}}
????#修匹配到的第一條記錄
????mycol.update_one(myquery, newvalues)
????# 輸出修改后的 "sites" 集合
????for?x in?mycol.find():
????????print(x)
????myquery = {"name": {"$regex": "^F"}}
????newvalues = {"$set": {"alexa": "66666"}}
????#修改所有匹配到的記錄
????x1 = mycol.update_many(myquery, newvalues)
????# 輸出修改后的 "sites" 集合
????for?x in?mycol.find():
????????print(x)
????print(x1.modified_count, "文檔已修改")


if?__name__ == "__main__":
????main()

輸出:

{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'alexa': '12345', 'url': 'https://www.taobao.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c494'), 'name': 'Facebook', 'alexa': '12356', 'url': 'https://www.facebook.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c495'), 'name': '知乎', 'alexa': '103', 'url': 'https://www.zhihu.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c496'), 'name': 'Github', 'alexa': '109', 'url': 'https://www.github.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'alexa': '12345', 'url': 'https://www.taobao.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c494'), 'name': 'Facebook', 'alexa': '66666', 'url': 'https://www.facebook.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c495'), 'name': '知乎', 'alexa': '103', 'url': 'https://www.zhihu.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c496'), 'name': 'Github', 'alexa': '109', 'url': 'https://www.github.com'}
1?文檔已修改

排序

sort() 方法第一個參數為要排序的字段,第二個字段指定排序規則,1 為升序,-1 為降序,默認為升序。

import?pymongo


def?main():
????myclient = pymongo.MongoClient('mongodb://localhost:27017/')
????mydb = myclient["loaderman"]
????mycol = mydb["t_site"]
????mydoc = mycol.find().sort("alexa")
????for?x in?mydoc:
????????print(x)



if?__name__ == "__main__":
????main()

輸出:

{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c495'), 'name': '知乎', 'alexa': '103', 'url': 'https://www.zhihu.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c496'), 'name': 'Github', 'alexa': '109', 'url': 'https://www.github.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c492'), 'name': 'Taobao', 'alexa': '12345', 'url': 'https://www.taobao.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c494'), 'name': 'Facebook', 'alexa': '66666', 'url': 'https://www.facebook.com'}

刪除數據

  • 用 delete_one() 方法來刪除一個文檔,該方法第一個參數為查詢對象,指定要刪除哪些數據。

  • 使用 delete_many() 方法來刪除多個文檔,該方法第一個參數為查詢對象,指定要刪除哪些數據。

  • delete_many() 方法如果傳入的是一個空的查詢對象,則會刪除集合中的所有文檔。

  • 使用 drop() 方法來刪除一個集合。

import?pymongo


def?main():
????myclient = pymongo.MongoClient('mongodb://localhost:27017/')
????mydb = myclient["loaderman"]
????mycol = mydb["t_site"]
????myquery = {"name": "Taobao"}

????mycol.delete_one(myquery)

????# 刪除后輸出
????for?x in?mycol.find():
????????print(x)
????myquery = {"name": {"$regex": "^F"}}

????x = mycol.delete_many(myquery)
????print(x.deleted_count, "個文檔已刪除")
????x = mycol.delete_many({})

????print(x.deleted_count, "個文檔已刪除")
????mycol.drop()


if?__name__ == "__main__":
????main()

輸出:

{'_id': ObjectId('5f05c10bfd36a6335af1c493'), 'name': 'QQ', 'alexa': '101', 'url': 'https://www.qq.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c494'), 'name': 'Facebook', 'alexa': '66666', 'url': 'https://www.facebook.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c495'), 'name': '知乎', 'alexa': '103', 'url': 'https://www.zhihu.com'}
{'_id': ObjectId('5f05c10bfd36a6335af1c496'), 'name': 'Github', 'alexa': '109', 'url': 'https://www.github.com'}
1?個文檔已刪除
3?個文檔已刪除

? 碼上加油站

? 一起來加油

長按掃碼關注

d9d3c7d3f4d7ebcd3dbd2e939d5fa999.png

點“在看”你懂得

0bd902120d2ff105ce4f5ce55b6a2b43.png

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/454445.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/454445.shtml
英文地址,請注明出處:http://en.pswp.cn/news/454445.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

checkbox已設置為checked--true-但不勾選問題解決方法(只第一次勾選有效)

一、出現的問題及解決方法: 今天在寫一個table相關插件的時候無意中發現了這樣一個問題,記得以前在寫這種控制checkbox選中與非選中的代碼時并沒有這種bug,當時也是用的checked屬性,而現在卻行不通了。 于是乎做了以下測試&#x…

Python 錯誤和異常小結[轉]

原文鏈接 http://blog.csdn.net/sinchb/article/details/8392827 事先說明哦,這不是一篇關于Python異常的全面介紹的文章,這只是在學習Python異常后的一篇筆記式的記錄和小結性質的文章。什么?你還不知道什么是異常,額... 1.Py…

Django REST framework 認證、權限和頻率組件

認證與權限頻率組件 身份驗證是將傳入請求與一組標識憑據(例如請求來自的用戶或其簽名的令牌)相關聯的機制。然后 權限 和 限制 組件決定是否拒絕這個請求。 簡單來說就是: 認證確定了你是誰權限確定你能不能訪問某個接口限制確定你訪問某…

高速率AVS整數變換的匯編實現與優化

1 引言 AVS標準Ⅲ采用的8x8整數變換在獲得較H.264更高的壓縮率和主觀圖像質量的同時,增加了算法的實現復雜性和時間開銷。本文重點研究AVS編解碼器的整數變換模塊,針對不同的算法實現模式,在原有Visual C6.0整數變換模…

計算機與廣播電視論文,淺談廣播電視中計算機技術的作用論文.pdf

1、計算機技術在廣播電視的媒體內容中有重要應用在以往的廣播電視中, 媒體內容主要分為音頻和視頻兩種信號, 在傳輸的過程中使用的是模擬信號, 但模擬信號受到的外界干擾因素較為明顯, 因此廣播電視傳播的媒體內容受到影響&#x…

opencv安裝教程python3.7_Mac下安裝使用Python-OpenCV,解決opencv3安裝完成無法使用的問題 - pytorch中文網...

OpenCV是一個跨平臺計算機視覺庫,可以運行在Linux、Windows、Android和Mac OS操作系統上。提供了Python、Ruby、MATLAB等語言的接口,實現了圖像處理和計算機視覺方面的很多通用算法。 Mac安裝OpenCV 在我們的深度學習的過程中,對于圖像&#…

NodeJS在CentOs7下安裝

node下載地址:https://nodejs.org/en/download/ 1.安裝gcc $ yum install gcc-c 2.解壓最新版本 $ mkdir /usr/local/node$ tar zxvf node-v6.11.4.tar.gz $ cd node-v6.11.4$ ./configure --prefix/usr/local/node# 在當前目錄下編譯安裝Node$ make$ make install 3.驗證安裝 …

Python功能之反射

有如下文件: index.py 1<span style"font-family:宋體, SimSun;">#!/usr/bin/env python<br data-filtered"filtered"># -*- coding:utf-8 -*-<br data-filtered"filtered">__author__ ryan<br data-filtered"filter…

Django REST framework 分頁

分頁模式 rest framework中提供了三種分頁模式&#xff1a; from rest_framework.pagination import PageNumberPagination, LimitOffsetPagination, CursorPagination 全局配置 REST_FRAMEWORK {DEFAULT_PAGINATION_CLASS: rest_framework.pagination.LimitOffsetPaginat…

解析H.264視頻編解碼DSP實現與優化

引言 基于互聯網的數字視頻產業前景看好&#xff0c;而3G的規模部署&#xff0c;也會推動移動視頻通信成為現實。但數字化后的視頻圖像具有數據海量性&#xff0c;給圖像的存儲和傳輸造成較大的困難。數字視頻產業&#xff0c;是指數字內容中以數字視頻形態為主的文化創意和傳播…

ap計算機科學a買什么書,準備AP*計算機科學A考試-第1部分

你將學到什么Identify the use and proper use of Variables, Conditionals, Objects and primitives, control structures, booleans, lists and arrays, and Exceptions.Implement problem descriptions in well designed code.Identify and begin to design algorithms to s…

python 打包exe_python如何封裝為exe

1、首先進入python安裝路徑D:\Python27\Scripts下&#xff0c;查看pip或easy_install是否安裝。2、確保安裝了pip或者easy_install&#xff0c;在cmd命令行下輸入“easy_install”&#xff0c;沒有提示“xxx不是內部或外部命令……”&#xff0c;就說明easy install工具安裝成功…

CentOS7安裝Hadoop2.7完整步驟

總體思路&#xff0c;準備主從服務器&#xff0c;配置主服務器可以無密碼SSH登錄從服務器&#xff0c;解壓安裝JDK&#xff0c;解壓安裝Hadoop&#xff0c;配置hdfs、mapreduce等主從關系。 1、環境&#xff0c;3臺CentOS7&#xff0c;64位&#xff0c;Hadoop2.7需要64位Linux&…

Django REST framework 解析器和渲染器

解析器的作用 解析器的作用就是服務端接收客戶端傳過來的數據&#xff0c;把數據解析成自己可以處理的數據。本質就是對請求體中的數據進行解析。 在了解解析器之前&#xff0c;我們要先知道Accept以及ContentType請求頭。 Accept是告訴對方我能解析什么樣的數據&#xff0c…

MyBatis的學習之路(二)

上篇文章介紹了MyBatis的配置文件&#xff0c;現在來介紹實體映射文件Mapper.xml。 說道實體映射文件&#xff0c;就不得不說一下實體與表之間的映射關系&#xff1a;單表映射和多表映射。 a. 單表映射 1 public class Admin{ 2 private String id; 3 private String n…

計算機一級實驗素材題目,計算機一級EXCEL操作題整理素材(12頁)-原創力文檔...

素材摘錄&#xff0c;文檔可編輯分享PAGE 頁碼頁碼/NUMPAGES 總頁數總頁數單元格合并首先選中你要合并的單元格&#xff0c;然后找到EXCEL上的開始分區里的這種圖標或者是含有“合并”兩字的位置如圖1-1&#xff0c;如果題目要求的是要你合并單元格并讓內容居中&#xff0c;你就…

python爬取toefl_spark學習進度6-Python爬取數據的四個簡單實例

今天本來想把昨天安裝的intellij配置好&#xff0c;但是一直顯示沒有網絡&#xff0c;網上查了相關資料也沒有查出來解決辦法。然后暫停了intellij的配置&#xff0c;開始做了幾個Python爬取簡單數據的實例&#xff0c;先做了幾個最簡單的&#xff0c;以后再加大難度&#xff0…

Django REST framework 版本

API 版本控制允許我們在不同的客戶端之間更改行為&#xff08;同一個接口的不同版本會返回不同的數據&#xff09;。 DRF提供了許多不同的版本控制方案。 可能會有一些客戶端因為某些原因不再維護了&#xff0c;但是我們后端的接口還要不斷的更新迭代&#xff0c;這個時候通過…

AngularJS中的過濾器(filter)

AngularJS中的過濾器是用于對數據的格式化&#xff0c;或者篩選的函數&#xff0c;可以直接通過以下語法使用&#xff1a; {{expression|filter}} {{expression|filter1|filter2}} {{expression|filter1:param1,param2,...|filter2} 過濾器的種類有number&#xff0c;currency&…

計算機考試上傳照片教程,電腦照片傳到iPhone手機的詳細步驟【圖文】

蘋果自帶的iOS系統是不可以隨便和電腦進行數據交換的&#xff0c;必須使用iTunes軟件。許多用戶為此問題困擾&#xff0c;我們有什么可以把電腦照片傳到iPhone手機&#xff1f;下面我們就一起來看看把電腦照片傳到iphone設備的詳細步驟。具體方法如下&#xff1a;1&#xff0c;…