asymongo


Nameasymongo JSON
Version 1.3.8.7 PyPI version JSON
download
home_pageNone
Summary异步的 MongoDB ORM
upload_time2023-11-26 05:11:23
maintainerNone
docs_urlNone
authorNone
requires_pythonNone
licenseNone
keywords asymongo motor mongodb pymongo orm
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # 项目描述

异步的 MongoDB ORM 。

# 作者信息

昵称:lcctoor.com

[主页](https://lcctoor.github.io/arts/) \| [微信](https://lcctoor.github.io/arts/arts/static/static-files/WeChatQRC.jpg) \| [Github](https://github.com/lcctoor) \| [PyPi](https://pypi.org/user/lcctoor) \| [Python交流群](https://lcctoor.github.io/arts/arts/static/static-files/PythonWeChatGroupQRC.jpg) \| [邮箱](mailto:lcctoor@outlook.com) \| [域名](http://lcctoor.com) \| [捐赠](https://lcctoor.github.io/arts/arts/static/static-files/DonationQRC-0rmb.jpg)

# Bug提交、功能提议

您可以通过 [Github-Issues](https://github.com/lcctoor/arts/issues)、[微信](https://lcctoor.github.io/arts/arts/static/static-files/WeChatQRC.jpg) 与我联系。

# 安装

```
pip install asymongo
```

# 教程 ([查看美化版](https://lcctoor.github.io/arts/?pk=asymongo)👈)

本文将以最简洁的方式向你介绍核心知识,而不会让你被繁琐的术语所淹没。

## 导入

```python
from motor.motor_asyncio import AsyncIOMotorClient as MongoClient
import asymongo as mg
from asymongo import mc, mup
```

## 创建ORM

```python
mkconn = lambda: MongoClient(host='localhost', port=27017)

orm = mg.ORM(mkconn)  # 账户ORM
db = orm['泉州市']  # 库ORM
sheet = db['希望小学']  # 表ORM
```

## 新增数据

```python
line1 = {'姓名': '小一', '年龄':11, '幸运数字':[1, 2, 3], '成绩':{'语文':81, '数学':82}}
line2 = {'姓名': '小二', '年龄':12, '幸运数字':[2, 3, 4], '成绩':{'语文':82, '数学':83}}
line3 = {'姓名': '小三', '年龄':13, '幸运数字':[3, 4, 5], '成绩':{'语文':83, '数学':84}}
line4 = {'姓名': '小四', '年龄':14, '幸运数字':[4, 5, 6], '成绩':{'语文':84, '数学':85}}
line5 = {'姓名': '小五', '年龄':15, '幸运数字':[5, 6, 7], '成绩':{'语文':85, '数学':86}}
line6 = {'姓名': '小六', '年龄':16, '幸运数字':[6, 7, 8], '成绩':{'语文':86, '数学':87}}

r1 = await sheet.insert(line1)  # 添加1条数据
r2 = await sheet.insert([ line2, line3, line4, line5, line6 ])  # 批量添加
```

查看分配到的主键:

方法1:添加数据成功后,line1~line6 已各自多了一个叫‘_id’的键,该键的值即分配到的主键。

方法2:

```python
r1.inserted_id
r2.inserted_ids
```

## 查询示例

```python
await sheet[:]  # 查询所有数据

await sheet[3]  # 查询第3条数据

await sheet[mc.成绩.语文 == 85][:]  # 查询语文成绩为85分的数据

await sheet[mc.年龄>13][mc.姓名=='小五'][1]  # 查询年龄大于13、且姓名叫'小五'的第1条数据
```

注:后文有关于查询的详细教程。

## 修改示例

```python
data = {
    '视力': 5.0,
    '性别': '男',
    '爱好': ['足球','篮球','画画','跳绳'],
    '幸运数字': mup.push(15,16,17),  # 添加到列表
    '年龄': mup.inc(2)  # 自增
}

await sheet.update(data)[2:5]
```

注:后文有关于修改的详细教程。

## 删除

```python
# 删除年龄>=15的数据
r1 = await sheet[mc.年龄>=15].delete()[:]

# 删除年龄大于10、且姓名包含'小'的第2条数据
r2 = await sheet[mc.年龄>10][mc.姓名 == mg.re('小')].delete()[2]

# 删除所有数据
r3 = await sheet.delete()[:]

# 查看删除详情
r1.raw_result
r2.raw_result
r3.raw_result
```

## 切片

1、切片格式为  [start: stop: step]  ,start 表示从哪条开始,stop 表示到哪条停止,step 表示步长。

2、start 和 stop

* 当为正值时,表示正序第 x 条,例如:1 表示第 1 条、2 表示第 2 条。
* 当为负值时,表示倒数第 x 条,例如:-1 表示倒数第 1 条、-2 表示倒数第 2 条。
* 不可为 0 。

3、step

* 须为正整数。
* 当 step >= 2  时表示间隔式切片。
* 当 step = 1 时可省略 `: step` ,即:[start: stop] 等价于 [start: stop: 1] 。

4、与 Python 切片风格对比

此 ORM 的切片风格比 Python 切片风格更人性化。具体区别为:

|                                        | **Python**                                                | **asymongo**                                              |
| -------------------------------------- | --------------------------------------------------------------- | --------------------------------------------------------------- |
| **索引**                         | 从 0 开始,例如:<br />[0] 表示第 1 个元素、[1] 表示第 2 个元素 | 从 1 开始,例如:<br />[1] 表示第 1 个元素、[2] 表示第 2 个元素 |
| **切片**                         | 左闭右开区间,例如:<br />[3: 5] 表示第 4~5 这 2 个元素         | 双闭区间,例如:<br />[3: 5] 表示第 3~5 这 3 个元素             |
| **从右往**<br />**左切片** | step 为负值,例如:<br />[9: 1: -1] 表示第 9~3 这 7 个元素     | step 为正值,例如:<br />[9: 1: 1] 表示第 9~1 这 9 个元素       |

### 示例

```python
await sheet[过滤器]...[过滤器][:]  # 查询符合条件的全部数据
await sheet[过滤器]...[过滤器][:] = None  # 删除符合条件的全部数据
await sheet[过滤器]...[过滤器][:] = {'年级':'初一'}  # 修改符合条件的全部数据

await sheet[过滤器]...[过滤器][1]  # 查询符合条件的第1条
await sheet[过滤器]...[过滤器][1] = None  # 删除符合条件的第1条
await sheet[过滤器]...[过滤器][1] = {'年级':'初一'}  # 修改符合条件的第1条

await sheet[过滤器]...[过滤器][3:7]  # 查询符合条件的第3~7条
await sheet[过滤器]...[过滤器][3:7] = None  # 删除符合条件的第3~7条
await sheet[过滤器]...[过滤器][3:7] = {'年级':'初一'}  # 修改符合条件的第3~7条

await sheet[过滤器]...[过滤器][3:7:2]  # 查询符合条件的第3、5、7条
await sheet[过滤器]...[过滤器][3:7:2] = None  # 删除符合条件的第3、5、7条
await sheet[过滤器]...[过滤器][3:7:2] = {'年级':'初一'}  # 修改符合条件的第3、5、7条
```

值得注意的地方:  [3: 8: 2]  操作第  3、5、7  条,而  [8: 3: 2]  操作第  8、6、4  条。

更多示例:

```python
[:]           # 所有数据
[1:-1]        # 所有数据
[-1:1]        # 所有数据(逆序)
[1:]          # 所有数据
[:1000]       # 第1条 ~ 第1000条
[:-1000]      # 第1条 ~ 倒数第1000条
[100:200]     # 第100条 ~ 第200条
[200:100]     # 第200条 ~ 第100条
[-300:-2]     # 倒数第300条 ~ 倒数第2条
[50:-2]       # 第50条 ~ 倒数第2条
[250:]        # 第250条 ~ 最后1条
[-250:]       # 倒数第250条 ~ 最后1条
[1]           # 第1条
[-1]          # 最后1条
[::3]         # 以3为间距, 间隔操作所有数据
[100:200:4]   # 以4为间距, 间隔操作第100条 ~ 第200条
```

## 过滤器

过滤器的结构为 `mc.<字段名称><运算符><值>` ,例如 `mc.年龄 > 18` 。

### 比较运算

| **代码** |
| -------------- |
| mc.年龄 > 10   |
| mc.年龄 >= 10  |
| mc.年龄 < 10   |
| mc.年龄 <= 10  |
| mc.年龄 == 10  |
| mc.年龄 != 10  |

### 成员运算

| **代码**                           | **解释**                          |
| ---------------------------------------- | --------------------------------------- |
| mc.年级 == mg.isin('初三', '高二')       | 若字段值是传入值的成员,则符合          |
| mc.年龄 == mg.notin(10, 30, 45)          | 若字段值不是传入值的成员,则符合        |
| mc.爱好 == mg.contain_all('画画', '足球') | 若字段值包含传入值的所有元素,则符合    |
| mc.爱好 == mg.contain_any('画画', '足球') | 若字段值包含传入值的至少1个元素,则符合 |
| mc.爱好 == mg.contain_none('画画', '足球')  | 若字段值不包含传入值的任何元素,则符合  |

注:

1、isin、notin与contain_all、contain_any、contain_none的区别:前者判断字段值是否传入值的成员,后者判断传入值是否字段值的成员。

2、isin、notin、contain_all、contain_any、contain_none 的传入值都不必是同类型的数据,以isin为例:可以这样使用:  mc.tag == mg.isin(3, 3.5, '学生', None)  ,传入值含有int型、float型、str型、None。

3、成员运算符未传入任何值时的处理方式:

| **代码**              | **处理方式** |
| --------------------------- | ------------------ |
| mc.年级 == mg.isin( )       | 所有数据都 不符合  |
| mc.年级 == mg.notin( )      | 所有数据都 符合    |
| mc.爱好 == mg.contain_all( ) | 所有数据都 符合    |
| mc.爱好 == mg.contain_any( ) | 所有数据都 不符合  |
| mc.爱好 == mg.contain_none( )  | 所有数据都 符合    |

### 正则运算

| **代码**         |
| ---------------------- |
| mc.姓名 == mg.re('小') |

### 过滤器的集合运算

| **代码**                                                       | **解释** |
| -------------------------------------------------------------------- | -------------- |
| [ mc.年龄>3 ][ mc.年龄<100 ]                                         | 交集           |
| [ (mc.年龄<30)\| (mc.年龄>30) \| (mc.年龄==30) \| (mc.年龄==None) ] | 并集           |
| [ (mc.年龄>3) - (mc.年龄>100) ]                                      | 差集           |
| [ ~(mc.年龄>100) ]                                                   | 补集           |

注:四种集合运算可以相互嵌套,且可以无限嵌套。

### 根据子元素过滤

可使用  mc.xxx.xxx.xxx  的形式来表示子孙元素。

查询语文成绩>80的数据:

```python
await sheet[mc.成绩.语文 > 80][:]
```

### 特殊字段名的表示方法

MongoDB支持各种特殊的字段名,如:数字、符号、emoji表情,这些字符在Python中不是合法变量名,使用  mc.1、mc.+  等格式会报错,可用  mc['1']、mc['+']  这种格式代替。

### 字段提示

变量 mc 无字段提示功能,输入‘mc.’后,编辑器不会提示可选字段。后文有关于如何设置字段提示的内容。

## 查询

### 限定返回字段

只返回姓名、年龄这2个字段:

```python
await sheet[mc.年级=='高一']['姓名','年龄'][:]
```

注:

1、字段限定器可放在sheet与[:]之间的任意位置。以下3行代码的返回结果相同:

```python
await sheet[mc.年龄>11][mc.年龄<30]['姓名', '年龄'][:]
await sheet[mc.年龄>11]['姓名', '年龄'][mc.年龄<30][:]
await sheet['姓名', '年龄'][mc.年龄>11][mc.年龄<30][:]
```

2、可反复限定字段,查询时是根据最后1次指定的字段提取数据。以下代码返回结果中只有‘年龄’字段:

```python
await sheet[mc.年级=='高一']['姓名']['年龄'][:]
```

3、若想恢复提取全部字段,则限定字段为mg.all_columns,mg.all_columns即代表“全部字段”。

```python
await sheet[mc.年级=='高一']['姓名'][mg.all_columns][:]
```

(为什么有时候要先限定字段,然后再取消限定,而不是一开始就不限定字段?这是因为在某些场景中这样做可以使代码整体上更优雅。参见后文 [ 如何写出优雅的代码 ](#如何写出优雅的代码) )

### 1个复杂的查询示例

```python
_ = sheet
_ = _[mc.年龄>=12]  # 比较
_ = _[mc.姓名 == mg.isin('小三','小四')]  # 被包含
_ = _[mc.姓名 == mg.notin('十三','十四')]  # 不被包含
_ = _[(mc.年龄==15) | (mc.年龄>15) | (mc.年龄<15)]  # 并集
_ = _[mc.年龄>=3][mc.年龄<100]  # 交集
_ = _[(mc.年龄>=3) - (mc.年龄>100)]  # 差集
_ = _[~ (mc.年龄>100)]  # 补集
_ = _[mc.姓名 == mg.re('小')]  # 正则表达式
_ = _[mc.幸运数字 == mg.contain_all(4, 5, 6)]  # 包含所有值
_ = _[mc.幸运数字 == mg.contain_any(4, 5, 6)]  # 包含至少1个值
_ = _[mc.幸运数字 == mg.contain_none(1, 2, 3)]  # 1个都不包含
await _[:]  # 切片
```

注:无论过滤器多复杂,ORM都不会访问数据库,只有在最后切片时,ORM才会访问数据库。

## 排序

对所有年龄>12的数据,优先按年龄降序,其次按姓名升序,排序后返回第2\~4条数据:

```python
await sheet[mc.年级=='高一'].order(年龄=False, 姓名=True)[2:4]
```

有趣的,以下两行代码的返回结果相同:

```python
await sheet[mc.年级=='高一'].order(年龄=True)[1:-1]

await sheet[mc.年级=='高一'].order(年龄=False)[-1:1]
```

解释:order(年龄=False)表示按年龄降序,[-1:1]表示逆序切片,产生了类似‘负负得正’的效果。

注:

1、排序器可放在sheet与[:]之间的任意位置。以下3行代码的返回结果相同:

```python
await sheet[mc.年级=='高一'][mc.视力>4.8].order(年龄=False)[2:4]
await sheet[mc.年级=='高一'].order(年龄=False)[mc.视力>4.8][2:4]
await sheet.order(年龄=False)[mc.年级=='高一'][mc.视力>4.8][2:4]
```

2、可反复排序,查询\|修改\|删除 时是根据最后1次指定的顺序提取数据。以下代码最终是按年龄降序后提取数据:

```python
await sheet.order(年龄=True, 姓名=False).order(年龄=False)[:]
```

3、若想取消排序,则再次调用order方法,但不传入任何值。

```python
await sheet.order(年龄=True, 姓名=False).order()[:]
```

(为什么有时候要先排序,然后再取消排序,而不是一开始就不排序?这是因为在某些场景中这样做可以使代码整体上更优雅。参见后文 [ 如何写出优雅的代码 ](#如何写出优雅的代码) )

## 修改

### 修改

```python
r = await sheet.update({'性别':'女'})[2:5]

r.raw_result  # 查看修改详情
```

### 特殊操作

执行以下代码后,年龄>10的数据中,第6、2条的年龄字段会增加1.5:

```python
data = {'年龄':mup.inc(1.5)}

await sheet[mc.年龄>10].update(data)[6:1:4]
```

特殊操作清单:

| **语法**       | **含义**                                     |
| -------------------- | -------------------------------------------------- |
| mup.inc(1)           | 自增1                                              |
| mup.inc(-1)          | 自减1                                              |
| mup.add(1, 2, 3)     | 向列表字段添加元素,仅当被添加的元素不存在时才添加 |
| mup.push(1, 2, 3)    | 向列表字段添加元素,无论被添加的元素是否存在都添加 |
| mup.pull(15)         | 从列表字段删除1个等于15的值                        |
| mup.popfirst         | 从列表字段删除第1个元素                            |
| mup.poplast          | 从列表字段删除最后1个元素                          |
| mup.rename('新名称') | 重命名字段                                         |
| mup.unset            | 删除字段                                           |
| mup.delete           | 删除字段(与mup.unset等价)                        |

对所有姓名为‘小六’的数据,姓名改为‘xiaoliu’,年龄自增6,幸运数字添加666,视力字段名改为‘眼力’,删除籍贯字段,语文成绩改为60分,数学成绩减10分:

```python
data = {
    '姓名': 'xiaoliu',
    '年龄': mup.inc(6),
    '幸运数字': mup.push(666),
    '视力': mup.rename('眼力'),
    '籍贯': mup.delete,
    '成绩.语文': 60,
    '成绩.数学': mup.inc(-10)
}

await sheet[mc.姓名=='小六'].update(data)[:]
```

## 统计

| **项目**            | **语法**                 |
| ------------------------- | ------------------------------ |
| 某张表的数据总量          | await sheet.len( )             |
| 某张表中,年龄>10的数据量 | await sheet[mc.年龄>10].len( ) |
| 库的数量                  | await orm.len( )               |
| 某个库中,表的数量        | await db.len( )                |

## 字段提示

变量 mc 无字段提示功能,输入‘mc.’后,编辑器不会提示可选字段。

为了获得字段提示功能,可自建一个‘mc2’:

```python
class mc2(mc):
    姓名 = 年龄 = 幸运数字 = None
    class 成绩:
        语文 = 数学 = None

await sheet[mc2.年龄 > 10][:]
await sheet[mc2.成绩.语文 > 80][:]
```

注:

1、mc2 与 mc 用法完全一致,可混用。

2、mc2 与 mc 设置字段提示后,仅具备提示效果,而不产生任何实际约束。

## 表ORM的独立性

### 表ORM的独立性

先看一条查询示例:

```python
await sheet[mc.年龄 > 5]['姓名','年龄'][mc.姓名 == mg.re('小')].order(_id=False)[:]
```

以上示例代码可改为如下(两者效果相同):

```python
d1 = sheet
d2 = d1[mc.年龄 > 5]
d3 = d2['姓名','年龄']
d4 = d3[mc.姓名 == mg.re('小')]
d5 = d4.order(_id=False)
await d5[:]
```

以上代码中,d1\~d5是5个不同的表ORM,它们具有独立的数据空间(存放着过滤条件、字段限定、排序等信息),且互不干扰。d2\~d5每个都拷贝了前一个ORM的表空间,并增加了自身的新信息。

### 如何写出优雅的代码

利用表ORM的独立性,可以在一些复杂的场景中写出优雅简洁的代码。

不优雅的示范:

```python
def GetName():
    return requests.get('https://...').text

def output(datas):
    ...

while True:
    datas = await sheet[过滤器1][过滤器2]...[过滤器9][mc.name == GetName()][:]
    output(datas)
```

优雅的示范:

```python
def GetName():
    return requests.get('https://...').text

def output(datas):
    ...

baseSheet = sheet[过滤器1][过滤器2]...[过滤器9]
while True:
    datas = await baseSheet[mc.name == GetName()][:]
    output(datas)
```

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "asymongo",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "asymongo,motor,mongodb,pymongo,orm",
    "author": null,
    "author_email": "\"lcctoor.com\" <lcctoor@outlook.com>",
    "download_url": "https://files.pythonhosted.org/packages/f4/18/5e7ec1aecf602a0ca77d0f3ecc70ca82c791389a11d680e4e88346aa3db3/asymongo-1.3.8.7.tar.gz",
    "platform": null,
    "description": "# \u9879\u76ee\u63cf\u8ff0\n\n\u5f02\u6b65\u7684 MongoDB ORM \u3002\n\n# \u4f5c\u8005\u4fe1\u606f\n\n\u6635\u79f0\uff1alcctoor.com\n\n[\u4e3b\u9875](https://lcctoor.github.io/arts/) \\| [\u5fae\u4fe1](https://lcctoor.github.io/arts/arts/static/static-files/WeChatQRC.jpg) \\| [Github](https://github.com/lcctoor) \\| [PyPi](https://pypi.org/user/lcctoor) \\| [Python\u4ea4\u6d41\u7fa4](https://lcctoor.github.io/arts/arts/static/static-files/PythonWeChatGroupQRC.jpg) \\| [\u90ae\u7bb1](mailto:lcctoor@outlook.com) \\| [\u57df\u540d](http://lcctoor.com) \\| [\u6350\u8d60](https://lcctoor.github.io/arts/arts/static/static-files/DonationQRC-0rmb.jpg)\n\n# Bug\u63d0\u4ea4\u3001\u529f\u80fd\u63d0\u8bae\n\n\u60a8\u53ef\u4ee5\u901a\u8fc7 [Github-Issues](https://github.com/lcctoor/arts/issues)\u3001[\u5fae\u4fe1](https://lcctoor.github.io/arts/arts/static/static-files/WeChatQRC.jpg) \u4e0e\u6211\u8054\u7cfb\u3002\n\n# \u5b89\u88c5\n\n```\npip install asymongo\n```\n\n# \u6559\u7a0b ([\u67e5\u770b\u7f8e\u5316\u7248](https://lcctoor.github.io/arts/?pk=asymongo)\ud83d\udc48)\n\n\u672c\u6587\u5c06\u4ee5\u6700\u7b80\u6d01\u7684\u65b9\u5f0f\u5411\u4f60\u4ecb\u7ecd\u6838\u5fc3\u77e5\u8bc6\uff0c\u800c\u4e0d\u4f1a\u8ba9\u4f60\u88ab\u7e41\u7410\u7684\u672f\u8bed\u6240\u6df9\u6ca1\u3002\n\n## \u5bfc\u5165\n\n```python\nfrom motor.motor_asyncio import AsyncIOMotorClient as MongoClient\nimport asymongo as mg\nfrom asymongo import mc, mup\n```\n\n## \u521b\u5efaORM\n\n```python\nmkconn = lambda: MongoClient(host='localhost', port=27017)\n\norm = mg.ORM(mkconn)  # \u8d26\u6237ORM\ndb = orm['\u6cc9\u5dde\u5e02']  # \u5e93ORM\nsheet = db['\u5e0c\u671b\u5c0f\u5b66']  # \u8868ORM\n```\n\n## \u65b0\u589e\u6570\u636e\n\n```python\nline1 = {'\u59d3\u540d': '\u5c0f\u4e00', '\u5e74\u9f84':11, '\u5e78\u8fd0\u6570\u5b57':[1, 2, 3], '\u6210\u7ee9':{'\u8bed\u6587':81, '\u6570\u5b66':82}}\nline2 = {'\u59d3\u540d': '\u5c0f\u4e8c', '\u5e74\u9f84':12, '\u5e78\u8fd0\u6570\u5b57':[2, 3, 4], '\u6210\u7ee9':{'\u8bed\u6587':82, '\u6570\u5b66':83}}\nline3 = {'\u59d3\u540d': '\u5c0f\u4e09', '\u5e74\u9f84':13, '\u5e78\u8fd0\u6570\u5b57':[3, 4, 5], '\u6210\u7ee9':{'\u8bed\u6587':83, '\u6570\u5b66':84}}\nline4 = {'\u59d3\u540d': '\u5c0f\u56db', '\u5e74\u9f84':14, '\u5e78\u8fd0\u6570\u5b57':[4, 5, 6], '\u6210\u7ee9':{'\u8bed\u6587':84, '\u6570\u5b66':85}}\nline5 = {'\u59d3\u540d': '\u5c0f\u4e94', '\u5e74\u9f84':15, '\u5e78\u8fd0\u6570\u5b57':[5, 6, 7], '\u6210\u7ee9':{'\u8bed\u6587':85, '\u6570\u5b66':86}}\nline6 = {'\u59d3\u540d': '\u5c0f\u516d', '\u5e74\u9f84':16, '\u5e78\u8fd0\u6570\u5b57':[6, 7, 8], '\u6210\u7ee9':{'\u8bed\u6587':86, '\u6570\u5b66':87}}\n\nr1 = await sheet.insert(line1)  # \u6dfb\u52a01\u6761\u6570\u636e\nr2 = await sheet.insert([ line2, line3, line4, line5, line6 ])  # \u6279\u91cf\u6dfb\u52a0\n```\n\n\u67e5\u770b\u5206\u914d\u5230\u7684\u4e3b\u952e\uff1a\n\n\u65b9\u6cd51\uff1a\u6dfb\u52a0\u6570\u636e\u6210\u529f\u540e\uff0cline1~line6 \u5df2\u5404\u81ea\u591a\u4e86\u4e00\u4e2a\u53eb\u2018_id\u2019\u7684\u952e\uff0c\u8be5\u952e\u7684\u503c\u5373\u5206\u914d\u5230\u7684\u4e3b\u952e\u3002\n\n\u65b9\u6cd52\uff1a\n\n```python\nr1.inserted_id\nr2.inserted_ids\n```\n\n## \u67e5\u8be2\u793a\u4f8b\n\n```python\nawait sheet[:]  # \u67e5\u8be2\u6240\u6709\u6570\u636e\n\nawait sheet[3]  # \u67e5\u8be2\u7b2c3\u6761\u6570\u636e\n\nawait sheet[mc.\u6210\u7ee9.\u8bed\u6587 == 85][:]  # \u67e5\u8be2\u8bed\u6587\u6210\u7ee9\u4e3a85\u5206\u7684\u6570\u636e\n\nawait sheet[mc.\u5e74\u9f84>13][mc.\u59d3\u540d=='\u5c0f\u4e94'][1]  # \u67e5\u8be2\u5e74\u9f84\u5927\u4e8e13\u3001\u4e14\u59d3\u540d\u53eb'\u5c0f\u4e94'\u7684\u7b2c1\u6761\u6570\u636e\n```\n\n\u6ce8\uff1a\u540e\u6587\u6709\u5173\u4e8e\u67e5\u8be2\u7684\u8be6\u7ec6\u6559\u7a0b\u3002\n\n## \u4fee\u6539\u793a\u4f8b\n\n```python\ndata = {\n    '\u89c6\u529b': 5.0,\n    '\u6027\u522b': '\u7537',\n    '\u7231\u597d': ['\u8db3\u7403','\u7bee\u7403','\u753b\u753b','\u8df3\u7ef3'],\n    '\u5e78\u8fd0\u6570\u5b57': mup.push(15,16,17),  # \u6dfb\u52a0\u5230\u5217\u8868\n    '\u5e74\u9f84': mup.inc(2)  # \u81ea\u589e\n}\n\nawait sheet.update(data)[2:5]\n```\n\n\u6ce8\uff1a\u540e\u6587\u6709\u5173\u4e8e\u4fee\u6539\u7684\u8be6\u7ec6\u6559\u7a0b\u3002\n\n## \u5220\u9664\n\n```python\n# \u5220\u9664\u5e74\u9f84>=15\u7684\u6570\u636e\nr1 = await sheet[mc.\u5e74\u9f84>=15].delete()[:]\n\n# \u5220\u9664\u5e74\u9f84\u5927\u4e8e10\u3001\u4e14\u59d3\u540d\u5305\u542b'\u5c0f'\u7684\u7b2c2\u6761\u6570\u636e\nr2 = await sheet[mc.\u5e74\u9f84>10][mc.\u59d3\u540d == mg.re('\u5c0f')].delete()[2]\n\n# \u5220\u9664\u6240\u6709\u6570\u636e\nr3 = await sheet.delete()[:]\n\n# \u67e5\u770b\u5220\u9664\u8be6\u60c5\nr1.raw_result\nr2.raw_result\nr3.raw_result\n```\n\n## \u5207\u7247\n\n1\u3001\u5207\u7247\u683c\u5f0f\u4e3a  [start: stop: step]  \uff0cstart \u8868\u793a\u4ece\u54ea\u6761\u5f00\u59cb\uff0cstop \u8868\u793a\u5230\u54ea\u6761\u505c\u6b62\uff0cstep \u8868\u793a\u6b65\u957f\u3002\n\n2\u3001start \u548c stop\n\n* \u5f53\u4e3a\u6b63\u503c\u65f6\uff0c\u8868\u793a\u6b63\u5e8f\u7b2c x \u6761\uff0c\u4f8b\u5982\uff1a1 \u8868\u793a\u7b2c 1 \u6761\u30012 \u8868\u793a\u7b2c 2 \u6761\u3002\n* \u5f53\u4e3a\u8d1f\u503c\u65f6\uff0c\u8868\u793a\u5012\u6570\u7b2c x \u6761\uff0c\u4f8b\u5982\uff1a-1 \u8868\u793a\u5012\u6570\u7b2c 1 \u6761\u3001-2 \u8868\u793a\u5012\u6570\u7b2c 2 \u6761\u3002\n* \u4e0d\u53ef\u4e3a 0 \u3002\n\n3\u3001step\n\n* \u987b\u4e3a\u6b63\u6574\u6570\u3002\n* \u5f53 step >= 2  \u65f6\u8868\u793a\u95f4\u9694\u5f0f\u5207\u7247\u3002\n* \u5f53 step = 1 \u65f6\u53ef\u7701\u7565 `: step` \uff0c\u5373\uff1a[start: stop] \u7b49\u4ef7\u4e8e [start: stop: 1] \u3002\n\n4\u3001\u4e0e Python \u5207\u7247\u98ce\u683c\u5bf9\u6bd4\n\n\u6b64 ORM \u7684\u5207\u7247\u98ce\u683c\u6bd4 Python \u5207\u7247\u98ce\u683c\u66f4\u4eba\u6027\u5316\u3002\u5177\u4f53\u533a\u522b\u4e3a\uff1a\n\n|                                        | **Python**                                                | **asymongo**                                              |\n| -------------------------------------- | --------------------------------------------------------------- | --------------------------------------------------------------- |\n| **\u7d22\u5f15**                         | \u4ece 0 \u5f00\u59cb\uff0c\u4f8b\u5982\uff1a<br />[0] \u8868\u793a\u7b2c 1 \u4e2a\u5143\u7d20\u3001[1] \u8868\u793a\u7b2c 2 \u4e2a\u5143\u7d20 | \u4ece 1 \u5f00\u59cb\uff0c\u4f8b\u5982\uff1a<br />[1] \u8868\u793a\u7b2c 1 \u4e2a\u5143\u7d20\u3001[2] \u8868\u793a\u7b2c 2 \u4e2a\u5143\u7d20 |\n| **\u5207\u7247**                         | \u5de6\u95ed\u53f3\u5f00\u533a\u95f4\uff0c\u4f8b\u5982\uff1a<br />[3: 5] \u8868\u793a\u7b2c 4~5 \u8fd9 2 \u4e2a\u5143\u7d20         | \u53cc\u95ed\u533a\u95f4\uff0c\u4f8b\u5982\uff1a<br />[3: 5] \u8868\u793a\u7b2c 3~5 \u8fd9 3 \u4e2a\u5143\u7d20             |\n| **\u4ece\u53f3\u5f80**<br />**\u5de6\u5207\u7247** | step\u00a0\u4e3a\u8d1f\u503c\uff0c\u4f8b\u5982\uff1a<br />[9: 1: -1] \u8868\u793a\u7b2c 9~3 \u8fd9 7 \u4e2a\u5143\u7d20     | step \u4e3a\u6b63\u503c\uff0c\u4f8b\u5982\uff1a<br />[9: 1: 1] \u8868\u793a\u7b2c 9~1 \u8fd9 9 \u4e2a\u5143\u7d20       |\n\n### \u793a\u4f8b\n\n```python\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][:]  # \u67e5\u8be2\u7b26\u5408\u6761\u4ef6\u7684\u5168\u90e8\u6570\u636e\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][:] = None  # \u5220\u9664\u7b26\u5408\u6761\u4ef6\u7684\u5168\u90e8\u6570\u636e\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][:] = {'\u5e74\u7ea7':'\u521d\u4e00'}  # \u4fee\u6539\u7b26\u5408\u6761\u4ef6\u7684\u5168\u90e8\u6570\u636e\n\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][1]  # \u67e5\u8be2\u7b26\u5408\u6761\u4ef6\u7684\u7b2c1\u6761\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][1] = None  # \u5220\u9664\u7b26\u5408\u6761\u4ef6\u7684\u7b2c1\u6761\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][1] = {'\u5e74\u7ea7':'\u521d\u4e00'}  # \u4fee\u6539\u7b26\u5408\u6761\u4ef6\u7684\u7b2c1\u6761\n\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][3:7]  # \u67e5\u8be2\u7b26\u5408\u6761\u4ef6\u7684\u7b2c3~7\u6761\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][3:7] = None  # \u5220\u9664\u7b26\u5408\u6761\u4ef6\u7684\u7b2c3~7\u6761\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][3:7] = {'\u5e74\u7ea7':'\u521d\u4e00'}  # \u4fee\u6539\u7b26\u5408\u6761\u4ef6\u7684\u7b2c3~7\u6761\n\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][3:7:2]  # \u67e5\u8be2\u7b26\u5408\u6761\u4ef6\u7684\u7b2c3\u30015\u30017\u6761\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][3:7:2] = None  # \u5220\u9664\u7b26\u5408\u6761\u4ef6\u7684\u7b2c3\u30015\u30017\u6761\nawait sheet[\u8fc7\u6ee4\u5668]...[\u8fc7\u6ee4\u5668][3:7:2] = {'\u5e74\u7ea7':'\u521d\u4e00'}  # \u4fee\u6539\u7b26\u5408\u6761\u4ef6\u7684\u7b2c3\u30015\u30017\u6761\n```\n\n\u503c\u5f97\u6ce8\u610f\u7684\u5730\u65b9\uff1a  [3: 8: 2]  \u64cd\u4f5c\u7b2c  3\u30015\u30017  \u6761\uff0c\u800c  [8: 3: 2]  \u64cd\u4f5c\u7b2c  8\u30016\u30014  \u6761\u3002\n\n\u66f4\u591a\u793a\u4f8b\uff1a\n\n```python\n[:]           # \u6240\u6709\u6570\u636e\n[1:-1]        # \u6240\u6709\u6570\u636e\n[-1:1]        # \u6240\u6709\u6570\u636e\uff08\u9006\u5e8f\uff09\n[1:]          # \u6240\u6709\u6570\u636e\n[:1000]       # \u7b2c1\u6761 ~ \u7b2c1000\u6761\n[:-1000]      # \u7b2c1\u6761 ~ \u5012\u6570\u7b2c1000\u6761\n[100:200]     # \u7b2c100\u6761 ~ \u7b2c200\u6761\n[200:100]     # \u7b2c200\u6761 ~ \u7b2c100\u6761\n[-300:-2]     # \u5012\u6570\u7b2c300\u6761 ~ \u5012\u6570\u7b2c2\u6761\n[50:-2]       # \u7b2c50\u6761 ~ \u5012\u6570\u7b2c2\u6761\n[250:]        # \u7b2c250\u6761 ~ \u6700\u540e1\u6761\n[-250:]       # \u5012\u6570\u7b2c250\u6761 ~ \u6700\u540e1\u6761\n[1]           # \u7b2c1\u6761\n[-1]          # \u6700\u540e1\u6761\n[::3]         # \u4ee53\u4e3a\u95f4\u8ddd, \u95f4\u9694\u64cd\u4f5c\u6240\u6709\u6570\u636e\n[100:200:4]   # \u4ee54\u4e3a\u95f4\u8ddd, \u95f4\u9694\u64cd\u4f5c\u7b2c100\u6761 ~ \u7b2c200\u6761\n```\n\n## \u8fc7\u6ee4\u5668\n\n\u8fc7\u6ee4\u5668\u7684\u7ed3\u6784\u4e3a `mc.<\u5b57\u6bb5\u540d\u79f0><\u8fd0\u7b97\u7b26><\u503c>` \uff0c\u4f8b\u5982 `mc.\u5e74\u9f84 > 18` \u3002\n\n### \u6bd4\u8f83\u8fd0\u7b97\n\n| **\u4ee3\u7801** |\n| -------------- |\n| mc.\u5e74\u9f84 > 10   |\n| mc.\u5e74\u9f84 >= 10  |\n| mc.\u5e74\u9f84 < 10   |\n| mc.\u5e74\u9f84 <= 10  |\n| mc.\u5e74\u9f84 == 10  |\n| mc.\u5e74\u9f84 != 10  |\n\n### \u6210\u5458\u8fd0\u7b97\n\n| **\u4ee3\u7801**                           | **\u89e3\u91ca**                          |\n| ---------------------------------------- | --------------------------------------- |\n| mc.\u5e74\u7ea7 == mg.isin('\u521d\u4e09', '\u9ad8\u4e8c')       | \u82e5\u5b57\u6bb5\u503c\u662f\u4f20\u5165\u503c\u7684\u6210\u5458\uff0c\u5219\u7b26\u5408          |\n| mc.\u5e74\u9f84 == mg.notin(10, 30, 45)          | \u82e5\u5b57\u6bb5\u503c\u4e0d\u662f\u4f20\u5165\u503c\u7684\u6210\u5458\uff0c\u5219\u7b26\u5408        |\n| mc.\u7231\u597d == mg.contain_all('\u753b\u753b', '\u8db3\u7403') | \u82e5\u5b57\u6bb5\u503c\u5305\u542b\u4f20\u5165\u503c\u7684\u6240\u6709\u5143\u7d20\uff0c\u5219\u7b26\u5408    |\n| mc.\u7231\u597d == mg.contain_any('\u753b\u753b', '\u8db3\u7403') | \u82e5\u5b57\u6bb5\u503c\u5305\u542b\u4f20\u5165\u503c\u7684\u81f3\u5c111\u4e2a\u5143\u7d20\uff0c\u5219\u7b26\u5408 |\n| mc.\u7231\u597d == mg.contain_none('\u753b\u753b', '\u8db3\u7403')  | \u82e5\u5b57\u6bb5\u503c\u4e0d\u5305\u542b\u4f20\u5165\u503c\u7684\u4efb\u4f55\u5143\u7d20\uff0c\u5219\u7b26\u5408  |\n\n\u6ce8\uff1a\n\n1\u3001isin\u3001notin\u4e0econtain_all\u3001contain_any\u3001contain_none\u7684\u533a\u522b\uff1a\u524d\u8005\u5224\u65ad\u5b57\u6bb5\u503c\u662f\u5426\u4f20\u5165\u503c\u7684\u6210\u5458\uff0c\u540e\u8005\u5224\u65ad\u4f20\u5165\u503c\u662f\u5426\u5b57\u6bb5\u503c\u7684\u6210\u5458\u3002\n\n2\u3001isin\u3001notin\u3001contain_all\u3001contain_any\u3001contain_none \u7684\u4f20\u5165\u503c\u90fd\u4e0d\u5fc5\u662f\u540c\u7c7b\u578b\u7684\u6570\u636e\uff0c\u4ee5isin\u4e3a\u4f8b\uff1a\u53ef\u4ee5\u8fd9\u6837\u4f7f\u7528\uff1a  mc.tag == mg.isin(3, 3.5, '\u5b66\u751f', None)  \uff0c\u4f20\u5165\u503c\u542b\u6709int\u578b\u3001float\u578b\u3001str\u578b\u3001None\u3002\n\n3\u3001\u6210\u5458\u8fd0\u7b97\u7b26\u672a\u4f20\u5165\u4efb\u4f55\u503c\u65f6\u7684\u5904\u7406\u65b9\u5f0f\uff1a\n\n| **\u4ee3\u7801**              | **\u5904\u7406\u65b9\u5f0f** |\n| --------------------------- | ------------------ |\n| mc.\u5e74\u7ea7 == mg.isin( )       | \u6240\u6709\u6570\u636e\u90fd \u4e0d\u7b26\u5408  |\n| mc.\u5e74\u7ea7 == mg.notin( )      | \u6240\u6709\u6570\u636e\u90fd \u7b26\u5408    |\n| mc.\u7231\u597d == mg.contain_all( ) | \u6240\u6709\u6570\u636e\u90fd \u7b26\u5408    |\n| mc.\u7231\u597d == mg.contain_any( ) | \u6240\u6709\u6570\u636e\u90fd \u4e0d\u7b26\u5408  |\n| mc.\u7231\u597d == mg.contain_none( )  | \u6240\u6709\u6570\u636e\u90fd \u7b26\u5408    |\n\n### \u6b63\u5219\u8fd0\u7b97\n\n| **\u4ee3\u7801**         |\n| ---------------------- |\n| mc.\u59d3\u540d == mg.re('\u5c0f') |\n\n### \u8fc7\u6ee4\u5668\u7684\u96c6\u5408\u8fd0\u7b97\n\n| **\u4ee3\u7801**                                                       | **\u89e3\u91ca** |\n| -------------------------------------------------------------------- | -------------- |\n| [ mc.\u5e74\u9f84>3 ][ mc.\u5e74\u9f84<100 ]                                         | \u4ea4\u96c6           |\n| [ (mc.\u5e74\u9f84<30)\\| (mc.\u5e74\u9f84>30) \\| (mc.\u5e74\u9f84==30)\u00a0\\| (mc.\u5e74\u9f84==None) ] | \u5e76\u96c6           |\n| [ (mc.\u5e74\u9f84>3) - (mc.\u5e74\u9f84>100) ]                                      | \u5dee\u96c6           |\n| [ ~(mc.\u5e74\u9f84>100) ]                                                   | \u8865\u96c6           |\n\n\u6ce8\uff1a\u56db\u79cd\u96c6\u5408\u8fd0\u7b97\u53ef\u4ee5\u76f8\u4e92\u5d4c\u5957\uff0c\u4e14\u53ef\u4ee5\u65e0\u9650\u5d4c\u5957\u3002\n\n### \u6839\u636e\u5b50\u5143\u7d20\u8fc7\u6ee4\n\n\u53ef\u4f7f\u7528  mc.xxx.xxx.xxx  \u7684\u5f62\u5f0f\u6765\u8868\u793a\u5b50\u5b59\u5143\u7d20\u3002\n\n\u67e5\u8be2\u8bed\u6587\u6210\u7ee9>80\u7684\u6570\u636e\uff1a\n\n```python\nawait sheet[mc.\u6210\u7ee9.\u8bed\u6587 > 80][:]\n```\n\n### \u7279\u6b8a\u5b57\u6bb5\u540d\u7684\u8868\u793a\u65b9\u6cd5\n\nMongoDB\u652f\u6301\u5404\u79cd\u7279\u6b8a\u7684\u5b57\u6bb5\u540d\uff0c\u5982\uff1a\u6570\u5b57\u3001\u7b26\u53f7\u3001emoji\u8868\u60c5\uff0c\u8fd9\u4e9b\u5b57\u7b26\u5728Python\u4e2d\u4e0d\u662f\u5408\u6cd5\u53d8\u91cf\u540d\uff0c\u4f7f\u7528  mc.1\u3001mc.+  \u7b49\u683c\u5f0f\u4f1a\u62a5\u9519\uff0c\u53ef\u7528  mc['1']\u3001mc['+']  \u8fd9\u79cd\u683c\u5f0f\u4ee3\u66ff\u3002\n\n### \u5b57\u6bb5\u63d0\u793a\n\n\u53d8\u91cf mc \u65e0\u5b57\u6bb5\u63d0\u793a\u529f\u80fd\uff0c\u8f93\u5165\u2018mc.\u2019\u540e\uff0c\u7f16\u8f91\u5668\u4e0d\u4f1a\u63d0\u793a\u53ef\u9009\u5b57\u6bb5\u3002\u540e\u6587\u6709\u5173\u4e8e\u5982\u4f55\u8bbe\u7f6e\u5b57\u6bb5\u63d0\u793a\u7684\u5185\u5bb9\u3002\n\n## \u67e5\u8be2\n\n### \u9650\u5b9a\u8fd4\u56de\u5b57\u6bb5\n\n\u53ea\u8fd4\u56de\u59d3\u540d\u3001\u5e74\u9f84\u8fd92\u4e2a\u5b57\u6bb5\uff1a\n\n```python\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00']['\u59d3\u540d','\u5e74\u9f84'][:]\n```\n\n\u6ce8\uff1a\n\n1\u3001\u5b57\u6bb5\u9650\u5b9a\u5668\u53ef\u653e\u5728sheet\u4e0e[:]\u4e4b\u95f4\u7684\u4efb\u610f\u4f4d\u7f6e\u3002\u4ee5\u4e0b3\u884c\u4ee3\u7801\u7684\u8fd4\u56de\u7ed3\u679c\u76f8\u540c\uff1a\n\n```python\nawait sheet[mc.\u5e74\u9f84>11][mc.\u5e74\u9f84<30]['\u59d3\u540d', '\u5e74\u9f84'][:]\nawait sheet[mc.\u5e74\u9f84>11]['\u59d3\u540d', '\u5e74\u9f84'][mc.\u5e74\u9f84<30][:]\nawait sheet['\u59d3\u540d', '\u5e74\u9f84'][mc.\u5e74\u9f84>11][mc.\u5e74\u9f84<30][:]\n```\n\n2\u3001\u53ef\u53cd\u590d\u9650\u5b9a\u5b57\u6bb5\uff0c\u67e5\u8be2\u65f6\u662f\u6839\u636e\u6700\u540e1\u6b21\u6307\u5b9a\u7684\u5b57\u6bb5\u63d0\u53d6\u6570\u636e\u3002\u4ee5\u4e0b\u4ee3\u7801\u8fd4\u56de\u7ed3\u679c\u4e2d\u53ea\u6709\u2018\u5e74\u9f84\u2019\u5b57\u6bb5\uff1a\n\n```python\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00']['\u59d3\u540d']['\u5e74\u9f84'][:]\n```\n\n3\u3001\u82e5\u60f3\u6062\u590d\u63d0\u53d6\u5168\u90e8\u5b57\u6bb5\uff0c\u5219\u9650\u5b9a\u5b57\u6bb5\u4e3amg.all_columns\uff0cmg.all_columns\u5373\u4ee3\u8868\u201c\u5168\u90e8\u5b57\u6bb5\u201d\u3002\n\n```python\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00']['\u59d3\u540d'][mg.all_columns][:]\n```\n\n\uff08\u4e3a\u4ec0\u4e48\u6709\u65f6\u5019\u8981\u5148\u9650\u5b9a\u5b57\u6bb5\uff0c\u7136\u540e\u518d\u53d6\u6d88\u9650\u5b9a\uff0c\u800c\u4e0d\u662f\u4e00\u5f00\u59cb\u5c31\u4e0d\u9650\u5b9a\u5b57\u6bb5\uff1f\u8fd9\u662f\u56e0\u4e3a\u5728\u67d0\u4e9b\u573a\u666f\u4e2d\u8fd9\u6837\u505a\u53ef\u4ee5\u4f7f\u4ee3\u7801\u6574\u4f53\u4e0a\u66f4\u4f18\u96c5\u3002\u53c2\u89c1\u540e\u6587 [ \u5982\u4f55\u5199\u51fa\u4f18\u96c5\u7684\u4ee3\u7801 ](#\u5982\u4f55\u5199\u51fa\u4f18\u96c5\u7684\u4ee3\u7801) \uff09\n\n### 1\u4e2a\u590d\u6742\u7684\u67e5\u8be2\u793a\u4f8b\n\n```python\n_ = sheet\n_ = _[mc.\u5e74\u9f84>=12]  # \u6bd4\u8f83\n_ = _[mc.\u59d3\u540d == mg.isin('\u5c0f\u4e09','\u5c0f\u56db')]  # \u88ab\u5305\u542b\n_ = _[mc.\u59d3\u540d == mg.notin('\u5341\u4e09','\u5341\u56db')]  # \u4e0d\u88ab\u5305\u542b\n_ = _[(mc.\u5e74\u9f84==15) | (mc.\u5e74\u9f84>15) | (mc.\u5e74\u9f84<15)]  # \u5e76\u96c6\n_ = _[mc.\u5e74\u9f84>=3][mc.\u5e74\u9f84<100]  # \u4ea4\u96c6\n_ = _[(mc.\u5e74\u9f84>=3) - (mc.\u5e74\u9f84>100)]  # \u5dee\u96c6\n_ = _[~ (mc.\u5e74\u9f84>100)]  # \u8865\u96c6\n_ = _[mc.\u59d3\u540d == mg.re('\u5c0f')]  # \u6b63\u5219\u8868\u8fbe\u5f0f\n_ = _[mc.\u5e78\u8fd0\u6570\u5b57 == mg.contain_all(4, 5, 6)]  # \u5305\u542b\u6240\u6709\u503c\n_ = _[mc.\u5e78\u8fd0\u6570\u5b57 == mg.contain_any(4, 5, 6)]  # \u5305\u542b\u81f3\u5c111\u4e2a\u503c\n_ = _[mc.\u5e78\u8fd0\u6570\u5b57 == mg.contain_none(1, 2, 3)]  # 1\u4e2a\u90fd\u4e0d\u5305\u542b\nawait _[:]  # \u5207\u7247\n```\n\n\u6ce8\uff1a\u65e0\u8bba\u8fc7\u6ee4\u5668\u591a\u590d\u6742\uff0cORM\u90fd\u4e0d\u4f1a\u8bbf\u95ee\u6570\u636e\u5e93\uff0c\u53ea\u6709\u5728\u6700\u540e\u5207\u7247\u65f6\uff0cORM\u624d\u4f1a\u8bbf\u95ee\u6570\u636e\u5e93\u3002\n\n## \u6392\u5e8f\n\n\u5bf9\u6240\u6709\u5e74\u9f84>12\u7684\u6570\u636e\uff0c\u4f18\u5148\u6309\u5e74\u9f84\u964d\u5e8f\uff0c\u5176\u6b21\u6309\u59d3\u540d\u5347\u5e8f\uff0c\u6392\u5e8f\u540e\u8fd4\u56de\u7b2c2\\~4\u6761\u6570\u636e\uff1a\n\n```python\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00'].order(\u5e74\u9f84=False, \u59d3\u540d=True)[2:4]\n```\n\n\u6709\u8da3\u7684\uff0c\u4ee5\u4e0b\u4e24\u884c\u4ee3\u7801\u7684\u8fd4\u56de\u7ed3\u679c\u76f8\u540c\uff1a\n\n```python\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00'].order(\u5e74\u9f84=True)[1:-1]\n\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00'].order(\u5e74\u9f84=False)[-1:1]\n```\n\n\u89e3\u91ca\uff1aorder(\u5e74\u9f84=False)\u8868\u793a\u6309\u5e74\u9f84\u964d\u5e8f\uff0c[-1:1]\u8868\u793a\u9006\u5e8f\u5207\u7247\uff0c\u4ea7\u751f\u4e86\u7c7b\u4f3c\u2018\u8d1f\u8d1f\u5f97\u6b63\u2019\u7684\u6548\u679c\u3002\n\n\u6ce8\uff1a\n\n1\u3001\u6392\u5e8f\u5668\u53ef\u653e\u5728sheet\u4e0e[:]\u4e4b\u95f4\u7684\u4efb\u610f\u4f4d\u7f6e\u3002\u4ee5\u4e0b3\u884c\u4ee3\u7801\u7684\u8fd4\u56de\u7ed3\u679c\u76f8\u540c\uff1a\n\n```python\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00'][mc.\u89c6\u529b>4.8].order(\u5e74\u9f84=False)[2:4]\nawait sheet[mc.\u5e74\u7ea7=='\u9ad8\u4e00'].order(\u5e74\u9f84=False)[mc.\u89c6\u529b>4.8][2:4]\nawait sheet.order(\u5e74\u9f84=False)[mc.\u5e74\u7ea7=='\u9ad8\u4e00'][mc.\u89c6\u529b>4.8][2:4]\n```\n\n2\u3001\u53ef\u53cd\u590d\u6392\u5e8f\uff0c\u67e5\u8be2\\|\u4fee\u6539\\|\u5220\u9664 \u65f6\u662f\u6839\u636e\u6700\u540e1\u6b21\u6307\u5b9a\u7684\u987a\u5e8f\u63d0\u53d6\u6570\u636e\u3002\u4ee5\u4e0b\u4ee3\u7801\u6700\u7ec8\u662f\u6309\u5e74\u9f84\u964d\u5e8f\u540e\u63d0\u53d6\u6570\u636e\uff1a\n\n```python\nawait sheet.order(\u5e74\u9f84=True, \u59d3\u540d=False).order(\u5e74\u9f84=False)[:]\n```\n\n3\u3001\u82e5\u60f3\u53d6\u6d88\u6392\u5e8f\uff0c\u5219\u518d\u6b21\u8c03\u7528order\u65b9\u6cd5\uff0c\u4f46\u4e0d\u4f20\u5165\u4efb\u4f55\u503c\u3002\n\n```python\nawait sheet.order(\u5e74\u9f84=True, \u59d3\u540d=False).order()[:]\n```\n\n\uff08\u4e3a\u4ec0\u4e48\u6709\u65f6\u5019\u8981\u5148\u6392\u5e8f\uff0c\u7136\u540e\u518d\u53d6\u6d88\u6392\u5e8f\uff0c\u800c\u4e0d\u662f\u4e00\u5f00\u59cb\u5c31\u4e0d\u6392\u5e8f\uff1f\u8fd9\u662f\u56e0\u4e3a\u5728\u67d0\u4e9b\u573a\u666f\u4e2d\u8fd9\u6837\u505a\u53ef\u4ee5\u4f7f\u4ee3\u7801\u6574\u4f53\u4e0a\u66f4\u4f18\u96c5\u3002\u53c2\u89c1\u540e\u6587 [ \u5982\u4f55\u5199\u51fa\u4f18\u96c5\u7684\u4ee3\u7801 ](#\u5982\u4f55\u5199\u51fa\u4f18\u96c5\u7684\u4ee3\u7801) \uff09\n\n## \u4fee\u6539\n\n### \u4fee\u6539\n\n```python\nr = await sheet.update({'\u6027\u522b':'\u5973'})[2:5]\n\nr.raw_result  # \u67e5\u770b\u4fee\u6539\u8be6\u60c5\n```\n\n### \u7279\u6b8a\u64cd\u4f5c\n\n\u6267\u884c\u4ee5\u4e0b\u4ee3\u7801\u540e\uff0c\u5e74\u9f84>10\u7684\u6570\u636e\u4e2d\uff0c\u7b2c6\u30012\u6761\u7684\u5e74\u9f84\u5b57\u6bb5\u4f1a\u589e\u52a01.5\uff1a\n\n```python\ndata = {'\u5e74\u9f84':mup.inc(1.5)}\n\nawait sheet[mc.\u5e74\u9f84>10].update(data)[6:1:4]\n```\n\n\u7279\u6b8a\u64cd\u4f5c\u6e05\u5355\uff1a\n\n| **\u8bed\u6cd5**       | **\u542b\u4e49**                                     |\n| -------------------- | -------------------------------------------------- |\n| mup.inc(1)           | \u81ea\u589e1                                              |\n| mup.inc(-1)          | \u81ea\u51cf1                                              |\n| mup.add(1, 2, 3)     | \u5411\u5217\u8868\u5b57\u6bb5\u6dfb\u52a0\u5143\u7d20\uff0c\u4ec5\u5f53\u88ab\u6dfb\u52a0\u7684\u5143\u7d20\u4e0d\u5b58\u5728\u65f6\u624d\u6dfb\u52a0 |\n| mup.push(1, 2, 3)    | \u5411\u5217\u8868\u5b57\u6bb5\u6dfb\u52a0\u5143\u7d20\uff0c\u65e0\u8bba\u88ab\u6dfb\u52a0\u7684\u5143\u7d20\u662f\u5426\u5b58\u5728\u90fd\u6dfb\u52a0 |\n| mup.pull(15)         | \u4ece\u5217\u8868\u5b57\u6bb5\u5220\u96641\u4e2a\u7b49\u4e8e15\u7684\u503c                        |\n| mup.popfirst         | \u4ece\u5217\u8868\u5b57\u6bb5\u5220\u9664\u7b2c1\u4e2a\u5143\u7d20                            |\n| mup.poplast          | \u4ece\u5217\u8868\u5b57\u6bb5\u5220\u9664\u6700\u540e1\u4e2a\u5143\u7d20                          |\n| mup.rename('\u65b0\u540d\u79f0') | \u91cd\u547d\u540d\u5b57\u6bb5                                         |\n| mup.unset            | \u5220\u9664\u5b57\u6bb5                                           |\n| mup.delete           | \u5220\u9664\u5b57\u6bb5\uff08\u4e0emup.unset\u7b49\u4ef7\uff09                        |\n\n\u5bf9\u6240\u6709\u59d3\u540d\u4e3a\u2018\u5c0f\u516d\u2019\u7684\u6570\u636e\uff0c\u59d3\u540d\u6539\u4e3a\u2018xiaoliu\u2019\uff0c\u5e74\u9f84\u81ea\u589e6\uff0c\u5e78\u8fd0\u6570\u5b57\u6dfb\u52a0666\uff0c\u89c6\u529b\u5b57\u6bb5\u540d\u6539\u4e3a\u2018\u773c\u529b\u2019\uff0c\u5220\u9664\u7c4d\u8d2f\u5b57\u6bb5\uff0c\u8bed\u6587\u6210\u7ee9\u6539\u4e3a60\u5206\uff0c\u6570\u5b66\u6210\u7ee9\u51cf10\u5206\uff1a\n\n```python\ndata = {\n    '\u59d3\u540d': 'xiaoliu',\n    '\u5e74\u9f84': mup.inc(6),\n    '\u5e78\u8fd0\u6570\u5b57': mup.push(666),\n    '\u89c6\u529b': mup.rename('\u773c\u529b'),\n    '\u7c4d\u8d2f': mup.delete,\n    '\u6210\u7ee9.\u8bed\u6587': 60,\n    '\u6210\u7ee9.\u6570\u5b66': mup.inc(-10)\n}\n\nawait sheet[mc.\u59d3\u540d=='\u5c0f\u516d'].update(data)[:]\n```\n\n## \u7edf\u8ba1\n\n| **\u9879\u76ee**            | **\u8bed\u6cd5**                 |\n| ------------------------- | ------------------------------ |\n| \u67d0\u5f20\u8868\u7684\u6570\u636e\u603b\u91cf          | await sheet.len( )             |\n| \u67d0\u5f20\u8868\u4e2d\uff0c\u5e74\u9f84>10\u7684\u6570\u636e\u91cf | await sheet[mc.\u5e74\u9f84>10].len( ) |\n| \u5e93\u7684\u6570\u91cf                  | await orm.len( )               |\n| \u67d0\u4e2a\u5e93\u4e2d\uff0c\u8868\u7684\u6570\u91cf        | await db.len( )                |\n\n## \u5b57\u6bb5\u63d0\u793a\n\n\u53d8\u91cf mc \u65e0\u5b57\u6bb5\u63d0\u793a\u529f\u80fd\uff0c\u8f93\u5165\u2018mc.\u2019\u540e\uff0c\u7f16\u8f91\u5668\u4e0d\u4f1a\u63d0\u793a\u53ef\u9009\u5b57\u6bb5\u3002\n\n\u4e3a\u4e86\u83b7\u5f97\u5b57\u6bb5\u63d0\u793a\u529f\u80fd\uff0c\u53ef\u81ea\u5efa\u4e00\u4e2a\u2018mc2\u2019\uff1a\n\n```python\nclass mc2(mc):\n    \u59d3\u540d = \u5e74\u9f84 = \u5e78\u8fd0\u6570\u5b57 = None\n    class \u6210\u7ee9:\n        \u8bed\u6587 = \u6570\u5b66 = None\n\nawait sheet[mc2.\u5e74\u9f84 > 10][:]\nawait sheet[mc2.\u6210\u7ee9.\u8bed\u6587 > 80][:]\n```\n\n\u6ce8\uff1a\n\n1\u3001mc2 \u4e0e mc \u7528\u6cd5\u5b8c\u5168\u4e00\u81f4\uff0c\u53ef\u6df7\u7528\u3002\n\n2\u3001mc2 \u4e0e mc \u8bbe\u7f6e\u5b57\u6bb5\u63d0\u793a\u540e\uff0c\u4ec5\u5177\u5907\u63d0\u793a\u6548\u679c\uff0c\u800c\u4e0d\u4ea7\u751f\u4efb\u4f55\u5b9e\u9645\u7ea6\u675f\u3002\n\n## \u8868ORM\u7684\u72ec\u7acb\u6027\n\n### \u8868ORM\u7684\u72ec\u7acb\u6027\n\n\u5148\u770b\u4e00\u6761\u67e5\u8be2\u793a\u4f8b\uff1a\n\n```python\nawait sheet[mc.\u5e74\u9f84 > 5]['\u59d3\u540d','\u5e74\u9f84'][mc.\u59d3\u540d == mg.re('\u5c0f')].order(_id=False)[:]\n```\n\n\u4ee5\u4e0a\u793a\u4f8b\u4ee3\u7801\u53ef\u6539\u4e3a\u5982\u4e0b\uff08\u4e24\u8005\u6548\u679c\u76f8\u540c\uff09\uff1a\n\n```python\nd1 = sheet\nd2 = d1[mc.\u5e74\u9f84 > 5]\nd3 = d2['\u59d3\u540d','\u5e74\u9f84']\nd4 = d3[mc.\u59d3\u540d == mg.re('\u5c0f')]\nd5 = d4.order(_id=False)\nawait d5[:]\n```\n\n\u4ee5\u4e0a\u4ee3\u7801\u4e2d\uff0cd1\\~d5\u662f5\u4e2a\u4e0d\u540c\u7684\u8868ORM\uff0c\u5b83\u4eec\u5177\u6709\u72ec\u7acb\u7684\u6570\u636e\u7a7a\u95f4\uff08\u5b58\u653e\u7740\u8fc7\u6ee4\u6761\u4ef6\u3001\u5b57\u6bb5\u9650\u5b9a\u3001\u6392\u5e8f\u7b49\u4fe1\u606f\uff09\uff0c\u4e14\u4e92\u4e0d\u5e72\u6270\u3002d2\\~d5\u6bcf\u4e2a\u90fd\u62f7\u8d1d\u4e86\u524d\u4e00\u4e2aORM\u7684\u8868\u7a7a\u95f4\uff0c\u5e76\u589e\u52a0\u4e86\u81ea\u8eab\u7684\u65b0\u4fe1\u606f\u3002\n\n### \u5982\u4f55\u5199\u51fa\u4f18\u96c5\u7684\u4ee3\u7801\n\n\u5229\u7528\u8868ORM\u7684\u72ec\u7acb\u6027\uff0c\u53ef\u4ee5\u5728\u4e00\u4e9b\u590d\u6742\u7684\u573a\u666f\u4e2d\u5199\u51fa\u4f18\u96c5\u7b80\u6d01\u7684\u4ee3\u7801\u3002\n\n\u4e0d\u4f18\u96c5\u7684\u793a\u8303\uff1a\n\n```python\ndef GetName():\n    return requests.get('https://...').text\n\ndef output(datas):\n    ...\n\nwhile True:\n    datas = await sheet[\u8fc7\u6ee4\u56681][\u8fc7\u6ee4\u56682]...[\u8fc7\u6ee4\u56689][mc.name == GetName()][:]\n    output(datas)\n```\n\n\u4f18\u96c5\u7684\u793a\u8303\uff1a\n\n```python\ndef GetName():\n    return requests.get('https://...').text\n\ndef output(datas):\n    ...\n\nbaseSheet = sheet[\u8fc7\u6ee4\u56681][\u8fc7\u6ee4\u56682]...[\u8fc7\u6ee4\u56689]\nwhile True:\n    datas = await baseSheet[mc.name == GetName()][:]\n    output(datas)\n```\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "\u5f02\u6b65\u7684 MongoDB ORM",
    "version": "1.3.8.7",
    "project_urls": {
        "HomePage": "https://github.com/lcctoor/arts/tree/main/arts/asymongo"
    },
    "split_keywords": [
        "asymongo",
        "motor",
        "mongodb",
        "pymongo",
        "orm"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "4ba6e60045ad9eab8fa350e1e53b6e81d5378ec4d35f63dd65c2ce76679e7c5d",
                "md5": "534b6fa036bd4b80ec8381a3bbd57892",
                "sha256": "e0cdc11070f2215b237e7f50d28a99ef837a66afe67165e2e01aa3a87039ce5f"
            },
            "downloads": -1,
            "filename": "asymongo-1.3.8.7-py2.py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "534b6fa036bd4b80ec8381a3bbd57892",
            "packagetype": "bdist_wheel",
            "python_version": "py2.py3",
            "requires_python": null,
            "size": 10880,
            "upload_time": "2023-11-26T05:11:18",
            "upload_time_iso_8601": "2023-11-26T05:11:18.326629Z",
            "url": "https://files.pythonhosted.org/packages/4b/a6/e60045ad9eab8fa350e1e53b6e81d5378ec4d35f63dd65c2ce76679e7c5d/asymongo-1.3.8.7-py2.py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "f4185e7ec1aecf602a0ca77d0f3ecc70ca82c791389a11d680e4e88346aa3db3",
                "md5": "fbe52456c510e3e6137530dbef344941",
                "sha256": "7c580d7c25cde0bd643248341e252bb904755301d7d8c746681255db6213846e"
            },
            "downloads": -1,
            "filename": "asymongo-1.3.8.7.tar.gz",
            "has_sig": false,
            "md5_digest": "fbe52456c510e3e6137530dbef344941",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 11969,
            "upload_time": "2023-11-26T05:11:23",
            "upload_time_iso_8601": "2023-11-26T05:11:23.061341Z",
            "url": "https://files.pythonhosted.org/packages/f4/18/5e7ec1aecf602a0ca77d0f3ecc70ca82c791389a11d680e4e88346aa3db3/asymongo-1.3.8.7.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-11-26 05:11:23",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "lcctoor",
    "github_project": "arts",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "asymongo"
}
        
Elapsed time: 0.15247s