-
-
Notifications
You must be signed in to change notification settings - Fork 89
Expand file tree
/
Copy pathmodule.po
More file actions
787 lines (678 loc) · 37.1 KB
/
module.po
File metadata and controls
787 lines (678 loc) · 37.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
# SOME DESCRIPTIVE TITLE.
# Copyright (C) 2001-2025, Python Software Foundation
# This file is distributed under the same license as the Python package.
# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
#
# Translators:
# python-doc bot, 2025
#
#, fuzzy
msgid ""
msgstr ""
"Project-Id-Version: Python 3.11\n"
"Report-Msgid-Bugs-To: \n"
"POT-Creation-Date: 2025-01-03 15:28+0000\n"
"PO-Revision-Date: 2025-09-22 16:49+0000\n"
"Last-Translator: python-doc bot, 2025\n"
"Language-Team: Chinese (China) (https://app.transifex.com/python-doc/teams/5390/zh_CN/)\n"
"MIME-Version: 1.0\n"
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
"Language: zh_CN\n"
"Plural-Forms: nplurals=1; plural=0;\n"
#: ../../c-api/module.rst:6
msgid "Module Objects"
msgstr "模块对象"
#: ../../c-api/module.rst:15
msgid ""
"This instance of :c:type:`PyTypeObject` represents the Python module type. "
"This is exposed to Python programs as ``types.ModuleType``."
msgstr ""
"这个 C 类型实例 :c:type:`PyTypeObject` 用来表示Python中的模块类型。在 Python 程序中该实例被暴露为 "
"``types.ModuleType``。"
#: ../../c-api/module.rst:21
msgid ""
"Return true if *p* is a module object, or a subtype of a module object. This"
" function always succeeds."
msgstr "当 *p* 为模块类型的对象,或是模块子类型的对象时返回真值。该函数永远有返回值。"
#: ../../c-api/module.rst:27
msgid ""
"Return true if *p* is a module object, but not a subtype of "
":c:data:`PyModule_Type`. This function always succeeds."
msgstr "当 *p* 为模块类型的对象且不是 :c:data:`PyModule_Type` 的子类型的对象时返回真值。该函数永远有返回值。"
#: ../../c-api/module.rst:40
msgid ""
"Return a new module object with the :attr:`__name__` attribute set to "
"*name*. The module's :attr:`__name__`, :attr:`__doc__`, :attr:`__package__`,"
" and :attr:`__loader__` attributes are filled in (all but :attr:`__name__` "
"are set to ``None``); the caller is responsible for providing a "
":attr:`__file__` attribute."
msgstr ""
"返回新的模块对象,其属性 :attr:`__name__` 为 *name* 。模块的如下属性 :attr:`__name__`, "
":attr:`__doc__`, :attr:`__package__`, and :attr:`__loader__` 都会被自动填充。(所有属性除了"
" :attr:`__name__` 都被设为 ``None``)。调用时应当提供 :attr:`__file__` 属性。"
#: ../../c-api/module.rst:48
msgid ":attr:`__package__` and :attr:`__loader__` are set to ``None``."
msgstr "属性 :attr:`__package__` 和 :attr:`__loader__` 被设为 ``None``。"
#: ../../c-api/module.rst:54
msgid ""
"Similar to :c:func:`PyModule_NewObject`, but the name is a UTF-8 encoded "
"string instead of a Unicode object."
msgstr "这类似于 :c:func:`PyModule_NewObject`, 但其名称为 UTF-8 编码的字符串而不是 Unicode 对象。"
#: ../../c-api/module.rst:62
msgid ""
"Return the dictionary object that implements *module*'s namespace; this "
"object is the same as the :attr:`~object.__dict__` attribute of the module "
"object. If *module* is not a module object (or a subtype of a module "
"object), :exc:`SystemError` is raised and ``NULL`` is returned."
msgstr ""
"返回实现 *module* 的命名空间的字典对象;此对象与模块对象的 :attr:`~object.__dict__` 属性相同。 如果 "
"*module* 不是一个模块对象(或模块对象的子类型),则会引发 :exc:`SystemError` 并返回 ``NULL``。"
#: ../../c-api/module.rst:67
msgid ""
"It is recommended extensions use other ``PyModule_*`` and ``PyObject_*`` "
"functions rather than directly manipulate a module's "
":attr:`~object.__dict__`."
msgstr ""
"建议扩展使用其他 ``PyModule_*`` 和 ``PyObject_*`` 函数而不是直接操纵模块的 "
":attr:`~object.__dict__`。"
#: ../../c-api/module.rst:78
msgid ""
"Return *module*'s :attr:`__name__` value. If the module does not provide "
"one, or if it is not a string, :exc:`SystemError` is raised and ``NULL`` is "
"returned."
msgstr ""
"返回 *module* 的 :attr:`__name__` 值。 如果模块未提供该值,或者如果它不是一个字符串,则会引发 "
":exc:`SystemError` 并返回 ``NULL``。"
#: ../../c-api/module.rst:86
msgid ""
"Similar to :c:func:`PyModule_GetNameObject` but return the name encoded to "
"``'utf-8'``."
msgstr "类似于 :c:func:`PyModule_GetNameObject` 但返回 ``'utf-8'`` 编码的名称。"
#: ../../c-api/module.rst:91
msgid ""
"Return the \"state\" of the module, that is, a pointer to the block of "
"memory allocated at module creation time, or ``NULL``. See "
":c:member:`PyModuleDef.m_size`."
msgstr ""
"返回模块的“状态”,也就是说,返回指向在模块创建时分配的内存块的指针,或者 ``NULL``。 参见 "
":c:member:`PyModuleDef.m_size`。"
#: ../../c-api/module.rst:98
msgid ""
"Return a pointer to the :c:type:`PyModuleDef` struct from which the module "
"was created, or ``NULL`` if the module wasn't created from a definition."
msgstr ""
"返回指向模块创建所使用的 :c:type:`PyModuleDef` 结构体的指针,或者如果模块不是使用结构体定义创建的则返回 ``NULL``。"
#: ../../c-api/module.rst:108
msgid ""
"Return the name of the file from which *module* was loaded using *module*'s "
":attr:`__file__` attribute. If this is not defined, or if it is not a "
"unicode string, raise :exc:`SystemError` and return ``NULL``; otherwise "
"return a reference to a Unicode object."
msgstr ""
"返回使用 *module* 的 :attr:`__file__` 属性所加载的 *模块* 的文件名。 如果属性未定义,或者如果它不是一个 Unicode"
" 字符串,则会引发 :exc:`SystemError` 并返回 ``NULL``;在其他情况下将返回一个指向 Unicode 对象的引用。"
#: ../../c-api/module.rst:118
msgid ""
"Similar to :c:func:`PyModule_GetFilenameObject` but return the filename "
"encoded to 'utf-8'."
msgstr "类似于 :c:func:`PyModule_GetFilenameObject` 但会返回编码为 'utf-8' 的文件名。"
#: ../../c-api/module.rst:121
msgid ""
":c:func:`PyModule_GetFilename` raises :exc:`UnicodeEncodeError` on "
"unencodable filenames, use :c:func:`PyModule_GetFilenameObject` instead."
msgstr ""
":c:func:`PyModule_GetFilename` 对于不可编码的文件名会引发 :exc:`UnicodeEncodeError`,请改用 "
":c:func:`PyModule_GetFilenameObject`。"
#: ../../c-api/module.rst:129
msgid "Initializing C modules"
msgstr "初始化 C 模块"
#: ../../c-api/module.rst:131
msgid ""
"Modules objects are usually created from extension modules (shared libraries"
" which export an initialization function), or compiled-in modules (where the"
" initialization function is added using :c:func:`PyImport_AppendInittab`). "
"See :ref:`building` or :ref:`extending-with-embedding` for details."
msgstr ""
"模块对象通常是基于扩展模块(导出初始化函数的共享库),或内部编译模块(其中使用 :c:func:`PyImport_AppendInittab` "
"添加初始化函数)。 请参阅 :ref:`building` 或 :ref:`extending-with-embedding` 了解详情。"
#: ../../c-api/module.rst:136
msgid ""
"The initialization function can either pass a module definition instance to "
":c:func:`PyModule_Create`, and return the resulting module object, or "
"request \"multi-phase initialization\" by returning the definition struct "
"itself."
msgstr ""
"初始化函数可以向 :c:func:`PyModule_Create` "
"传入一个模块定义实例,并返回结果模块对象,或者通过返回定义结构体本身来请求“多阶段初始化”。"
#: ../../c-api/module.rst:142
msgid ""
"The module definition struct, which holds all information needed to create a"
" module object. There is usually only one statically initialized variable of"
" this type for each module."
msgstr "模块定义结构,它保存创建模块对象所需的所有信息。每个模块通常只有一个这种类型的静态初始化变量"
#: ../../c-api/module.rst:148
msgid "Always initialize this member to :c:macro:`PyModuleDef_HEAD_INIT`."
msgstr "始终将此成员初始化为 :c:macro:`PyModuleDef_HEAD_INIT`。"
#: ../../c-api/module.rst:152
msgid "Name for the new module."
msgstr "新模块的名称。"
#: ../../c-api/module.rst:156
msgid ""
"Docstring for the module; usually a docstring variable created with "
":c:macro:`PyDoc_STRVAR` is used."
msgstr "模块的文档字符串;一般会使用通过 :c:macro:`PyDoc_STRVAR` 创建的文档字符串变量。"
#: ../../c-api/module.rst:161
msgid ""
"Module state may be kept in a per-module memory area that can be retrieved "
"with :c:func:`PyModule_GetState`, rather than in static globals. This makes "
"modules safe for use in multiple sub-interpreters."
msgstr ""
"可以把模块的状态保存在为单个模块分配的内存区域中,使用 :c:func:`PyModule_GetState` "
"检索,而不是保存在静态全局区。这使得模块可以在多个子解释器中安全地使用。"
#: ../../c-api/module.rst:165
msgid ""
"This memory area is allocated based on *m_size* on module creation, and "
"freed when the module object is deallocated, after the "
":c:member:`~PyModuleDef.m_free` function has been called, if present."
msgstr ""
"这个内存区域将在创建模块时根据 *m_size* 分配,并在调用 :c:member:`~PyModuleDef.m_free` "
"函数(如果存在)在取消分配模块对象时释放。"
#: ../../c-api/module.rst:169
msgid ""
"Setting ``m_size`` to ``-1`` means that the module does not support sub-"
"interpreters, because it has global state."
msgstr "将 ``m_size`` 设置为 ``-1``,意味着这个模块具有全局状态,因此不支持子解释器。"
#: ../../c-api/module.rst:172
msgid ""
"Setting it to a non-negative value means that the module can be re-"
"initialized and specifies the additional amount of memory it requires for "
"its state. Non-negative ``m_size`` is required for multi-phase "
"initialization."
msgstr "将其设置为非负值,意味着模块可以重新初始化,并指定其状态所需要的额外内存大小。多阶段初始化需要非负的 ``m_size``。"
#: ../../c-api/module.rst:177
msgid "See :PEP:`3121` for more details."
msgstr "请参阅 :PEP:`3121` 了解详情。"
#: ../../c-api/module.rst:181
msgid ""
"A pointer to a table of module-level functions, described by "
":c:type:`PyMethodDef` values. Can be ``NULL`` if no functions are present."
msgstr "一个指向模块函数表的指针,由 :c:type:`PyMethodDef` 描述。如果模块没有函数,可以为 ``NULL``。"
#: ../../c-api/module.rst:186
msgid ""
"An array of slot definitions for multi-phase initialization, terminated by a"
" ``{0, NULL}`` entry. When using single-phase initialization, *m_slots* must"
" be ``NULL``."
msgstr ""
"由针对多阶段初始化的槽位定义组成的数组,以一个 ``{0, NULL}`` 条目结束。 当使用单阶段初始化时,*m_slots* 必须为 "
"``NULL``。"
#: ../../c-api/module.rst:192
msgid ""
"Prior to version 3.5, this member was always set to ``NULL``, and was "
"defined as:"
msgstr "在 3.5 版之前,此成员总是被设为 ``NULL``,并被定义为:"
#: ../../c-api/module.rst:199
msgid ""
"A traversal function to call during GC traversal of the module object, or "
"``NULL`` if not needed."
msgstr "在模块对象的垃圾回收遍历期间所调用的遍历函数,如果不需要则为 ``NULL``。"
#: ../../c-api/module.rst:202 ../../c-api/module.rst:217
#: ../../c-api/module.rst:238
msgid ""
"This function is not called if the module state was requested but is not "
"allocated yet. This is the case immediately after the module is created and "
"before the module is executed (:c:data:`Py_mod_exec` function). More "
"precisely, this function is not called if :c:member:`~PyModuleDef.m_size` is"
" greater than 0 and the module state (as returned by "
":c:func:`PyModule_GetState`) is ``NULL``."
msgstr ""
"如果模块状态已被请求但尚未分配则不会调用此函数。 在模块创建之后至模块执行之前(调用 :c:data:`Py_mod_exec` 函数)就属于这种情况。"
" 更确切地说,如果 :c:member:`~PyModuleDef.m_size` 大于 0 且模块状态(由 "
":c:func:`PyModule_GetState` 返回)为 ``NULL`` 则不会调用此函数。"
#: ../../c-api/module.rst:209 ../../c-api/module.rst:230
#: ../../c-api/module.rst:245
msgid "No longer called before the module state is allocated."
msgstr "在模块状态被分配之前不再调用。"
#: ../../c-api/module.rst:214
msgid ""
"A clear function to call during GC clearing of the module object, or "
"``NULL`` if not needed."
msgstr "在模块对象的垃圾回收清理期间所调用的清理函数,如果不需要则为 ``NULL``。"
#: ../../c-api/module.rst:224
msgid ""
"Like :c:member:`PyTypeObject.tp_clear`, this function is not *always* called"
" before a module is deallocated. For example, when reference counting is "
"enough to determine that an object is no longer used, the cyclic garbage "
"collector is not involved and :c:member:`~PyModuleDef.m_free` is called "
"directly."
msgstr ""
"就像 :c:member:`PyTypeObject.tp_clear` "
"那样,这个函数并不总是在模块被释放前被调用。例如,当引用计数足以确定一个对象不再被使用时,就会直接调用 "
":c:member:`~PyModuleDef.m_free`,而不使用循环垃圾回收器。"
#: ../../c-api/module.rst:235
msgid ""
"A function to call during deallocation of the module object, or ``NULL`` if "
"not needed."
msgstr "在模块对象的释放期间所调用的函数,如果不需要则为 ``NULL``。"
#: ../../c-api/module.rst:249
msgid "Single-phase initialization"
msgstr "单阶段初始化"
#: ../../c-api/module.rst:251
msgid ""
"The module initialization function may create and return the module object "
"directly. This is referred to as \"single-phase initialization\", and uses "
"one of the following two module creation functions:"
msgstr "模块初始化函数可以直接创建并返回模块对象,称为“单阶段初始化”,使用以下两个模块创建函数中的一个:"
#: ../../c-api/module.rst:257
msgid ""
"Create a new module object, given the definition in *def*. This behaves "
"like :c:func:`PyModule_Create2` with *module_api_version* set to "
":c:macro:`PYTHON_API_VERSION`."
msgstr ""
"根据在 *def* 中给出的定义创建一个新的模块对象。 它的行为类似于 :c:func:`PyModule_Create2` 将 "
"*module_api_version* 设为 :c:macro:`PYTHON_API_VERSION`。"
#: ../../c-api/module.rst:264
msgid ""
"Create a new module object, given the definition in *def*, assuming the API "
"version *module_api_version*. If that version does not match the version of"
" the running interpreter, a :exc:`RuntimeWarning` is emitted."
msgstr ""
"创建一个新的模块对象,在参数 *def* 中给出定义,设定API版本为参数 *module_api_version* "
"。如果该版本与正在运行的解释器版本不匹配,则会触发 :exc:`RuntimeWarning`。"
#: ../../c-api/module.rst:270
msgid ""
"Most uses of this function should be using :c:func:`PyModule_Create` "
"instead; only use this if you are sure you need it."
msgstr "大多数时候应该使用 :c:func:`PyModule_Create` 代替使用此函数,除非你确定需要使用它。"
#: ../../c-api/module.rst:273
msgid ""
"Before it is returned from in the initialization function, the resulting "
"module object is typically populated using functions like "
":c:func:`PyModule_AddObjectRef`."
msgstr "在初始化函数返回之前,生成的模块对象通常使用 :c:func:`PyModule_AddObjectRef` 等函数进行填充。"
#: ../../c-api/module.rst:279
msgid "Multi-phase initialization"
msgstr "多阶段初始化"
#: ../../c-api/module.rst:281
msgid ""
"An alternate way to specify extensions is to request \"multi-phase "
"initialization\". Extension modules created this way behave more like Python"
" modules: the initialization is split between the *creation phase*, when the"
" module object is created, and the *execution phase*, when it is populated. "
"The distinction is similar to the :py:meth:`!__new__` and "
":py:meth:`!__init__` methods of classes."
msgstr ""
"指定扩展的另一种方式是请求“多阶段初始化”。 以这种方式创建的扩展模块的行为更类似 Python 模块:初始化分为 *创建阶段* 即创建模块对象时和 "
"*执行阶段* 即填充模块对象时。 这种区分类似于类的 :py:meth:`!__new__` 和 :py:meth:`!__init__` 方法。"
#: ../../c-api/module.rst:288
msgid ""
"Unlike modules created using single-phase initialization, these modules are "
"not singletons: if the *sys.modules* entry is removed and the module is re-"
"imported, a new module object is created, and the old module is subject to "
"normal garbage collection -- as with Python modules. By default, multiple "
"modules created from the same definition should be independent: changes to "
"one should not affect the others. This means that all state should be "
"specific to the module object (using e.g. using "
":c:func:`PyModule_GetState`), or its contents (such as the module's "
":attr:`~object.__dict__` or individual classes created with "
":c:func:`PyType_FromSpec`)."
msgstr ""
"与使用单阶段初始化创建的模块不同,这些模块不是单例:如果移除 *sys.modules* "
"条目并重新导入模块,将会创建一个新的模块对象,而旧的模块则会成为常规的垃圾回收目标 —— 就像 Python 模块那样。 "
"默认情况下,根据同一个定义创建的多个模块应该是相互独立的:对其中一个模块的更改不应影响其他模块。 这意味着所有状态都应该是模块对象 (例如使用 "
":c:func:`PyModule_GetState` ) 或其内容 (例如模块的 :attr:`~object.__dict__` 或使用 "
":c:func:`PyType_FromSpec` 创建的单独类) 的特定状态。"
#: ../../c-api/module.rst:298
msgid ""
"All modules created using multi-phase initialization are expected to support"
" :ref:`sub-interpreters <sub-interpreter-support>`. Making sure multiple "
"modules are independent is typically enough to achieve this."
msgstr ""
"所有使用多阶段初始化创建的模块都应该支持 :ref:`子解释器<sub-interpreter-"
"support>`。保证多个模块之间相互独立,通常就可以实现这一点。"
#: ../../c-api/module.rst:302
msgid ""
"To request multi-phase initialization, the initialization function "
"(PyInit_modulename) returns a :c:type:`PyModuleDef` instance with non-empty "
":c:member:`~PyModuleDef.m_slots`. Before it is returned, the ``PyModuleDef``"
" instance must be initialized with the following function:"
msgstr ""
"要请求多阶段初始化,初始化函数 (PyInit_modulename) 返回一个包含非空的 "
":c:member:`~PyModuleDef.m_slots` 属性的 :c:type:`PyModuleDef` 实例。在它被返回之前,这个 "
"``PyModuleDef`` 实例必须先使用以下函数初始化:"
#: ../../c-api/module.rst:309
msgid ""
"Ensures a module definition is a properly initialized Python object that "
"correctly reports its type and reference count."
msgstr "确保模块定义是一个正确初始化的Python对象,拥有正确的类型和引用计数。"
#: ../../c-api/module.rst:312
msgid "Returns *def* cast to ``PyObject*``, or ``NULL`` if an error occurred."
msgstr "返回转换为 ``PyObject*`` 的 *def* ,如果发生错误,则返回 ``NULL``。"
#: ../../c-api/module.rst:316
msgid ""
"The *m_slots* member of the module definition must point to an array of "
"``PyModuleDef_Slot`` structures:"
msgstr "模块定义的 *m_slots* 成员必须指向一个 ``PyModuleDef_Slot`` 结构体数组:"
#: ../../c-api/module.rst:323
msgid "A slot ID, chosen from the available values explained below."
msgstr "槽位 ID,从下面介绍的可用值中选择。"
#: ../../c-api/module.rst:327
msgid "Value of the slot, whose meaning depends on the slot ID."
msgstr "槽位值,其含义取决于槽位 ID。"
#: ../../c-api/module.rst:331
msgid "The *m_slots* array must be terminated by a slot with id 0."
msgstr "*m_slots* 数组必须以一个 id 为 0 的槽位结束。"
#: ../../c-api/module.rst:333
msgid "The available slot types are:"
msgstr "可用的槽位类型是:"
#: ../../c-api/module.rst:337
msgid ""
"Specifies a function that is called to create the module object itself. The "
"*value* pointer of this slot must point to a function of the signature:"
msgstr "指定一个函数供调用以创建模块对象本身。 该槽位的 *value* 指针必须指向一个具有如下签名的函数:"
#: ../../c-api/module.rst:343
msgid ""
"The function receives a :py:class:`~importlib.machinery.ModuleSpec` "
"instance, as defined in :PEP:`451`, and the module definition. It should "
"return a new module object, or set an error and return ``NULL``."
msgstr ""
"该函数接受一个 :py:class:`~importlib.machinery.ModuleSpec` 实例,如 :PEP:`451` "
"所定义的,以及模块定义。 它应当返回一个新的模块对象,或者设置一个错误并返回 ``NULL``。"
#: ../../c-api/module.rst:348
msgid ""
"This function should be kept minimal. In particular, it should not call "
"arbitrary Python code, as trying to import the same module again may result "
"in an infinite loop."
msgstr "此函数应当保持最小化。 特别地,它不应当调用任意 Python 代码,因为尝试再次导入同一个模块可能会导致无限循环。"
#: ../../c-api/module.rst:352
msgid ""
"Multiple ``Py_mod_create`` slots may not be specified in one module "
"definition."
msgstr "多个 ``Py_mod_create`` 槽位不能在一个模块定义中指定。"
#: ../../c-api/module.rst:355
msgid ""
"If ``Py_mod_create`` is not specified, the import machinery will create a "
"normal module object using :c:func:`PyModule_New`. The name is taken from "
"*spec*, not the definition, to allow extension modules to dynamically adjust"
" to their place in the module hierarchy and be imported under different "
"names through symlinks, all while sharing a single module definition."
msgstr ""
"如果未指定 ``Py_mod_create``,导入机制将使用 :c:func:`PyModule_New` 创建一个普通的模块对象。 名称是获取自 "
"*spec* 而非定义,以允许扩展模块动态地调整它们在模块层级结构中的位置并通过符号链接以不同的名称被导入,同时共享同一个模块定义。"
#: ../../c-api/module.rst:361
msgid ""
"There is no requirement for the returned object to be an instance of "
":c:type:`PyModule_Type`. Any type can be used, as long as it supports "
"setting and getting import-related attributes. However, only "
"``PyModule_Type`` instances may be returned if the ``PyModuleDef`` has "
"non-``NULL`` ``m_traverse``, ``m_clear``, ``m_free``; non-zero ``m_size``; "
"or slots other than ``Py_mod_create``."
msgstr ""
"不要求返回的对象必须为 :c:type:`PyModule_Type` 的实例。 任何类型均可使用,只要它支持设置和获取导入相关的属性。 但是,如果 "
"``PyModuleDef`` 具有非 ``NULL`` 的 ``m_traverse``, ``m_clear``, ``m_free``;非零的 "
"``m_size``;或者 ``Py_mod_create`` 以外的槽位则只能返回 ``PyModule_Type`` 的实例。"
#: ../../c-api/module.rst:370
msgid ""
"Specifies a function that is called to *execute* the module. This is "
"equivalent to executing the code of a Python module: typically, this "
"function adds classes and constants to the module. The signature of the "
"function is:"
msgstr "指定一个供调用以 *执行* 模块的函数。 这造价于执行一个 Python 模块的代码:通常,此函数会向模块添加类和常量。 此函数的签名为:"
#: ../../c-api/module.rst:378
msgid ""
"If multiple ``Py_mod_exec`` slots are specified, they are processed in the "
"order they appear in the *m_slots* array."
msgstr "如果指定了多个 ``Py_mod_exec`` 槽位,将按照它们在*m_slots*数组中出现的顺序进行处理。"
#: ../../c-api/module.rst:381
msgid "See :PEP:`489` for more details on multi-phase initialization."
msgstr "有关多阶段初始化的更多细节,请参阅PEP:`489`"
#: ../../c-api/module.rst:384
msgid "Low-level module creation functions"
msgstr "底层模块创建函数"
#: ../../c-api/module.rst:386
msgid ""
"The following functions are called under the hood when using multi-phase "
"initialization. They can be used directly, for example when creating module "
"objects dynamically. Note that both ``PyModule_FromDefAndSpec`` and "
"``PyModule_ExecDef`` must be called to fully initialize a module."
msgstr ""
"当使用多阶段初始化时,将会调用以下函数。例如,在动态创建模块对象的时候,可以直接使用它们。注意,必须调用 "
"``PyModule_FromDefAndSpec`` 和 ``PyModule_ExecDef`` 来完整地初始化一个模块。"
#: ../../c-api/module.rst:393
msgid ""
"Create a new module object, given the definition in *def* and the ModuleSpec"
" *spec*. This behaves like :c:func:`PyModule_FromDefAndSpec2` with "
"*module_api_version* set to :c:macro:`PYTHON_API_VERSION`."
msgstr ""
"根据在 *def* 中给出的定义和 ModuleSpec *spec* 创建一个新的模块对象。 它的行为类似于 "
":c:func:`PyModule_FromDefAndSpec2` 将 *module_api_version* 设为 "
":c:macro:`PYTHON_API_VERSION`。"
#: ../../c-api/module.rst:401
msgid ""
"Create a new module object, given the definition in *def* and the ModuleSpec"
" *spec*, assuming the API version *module_api_version*. If that version does"
" not match the version of the running interpreter, a :exc:`RuntimeWarning` "
"is emitted."
msgstr ""
"创建一个新的模块对象,在参数 *def* 和 *spec* 中给出定义,设置API版本为参数 "
"*module_api_version*。如果该版本与正在运行的解释器版本不匹配,则会触发 :exc:`RuntimeWarning`。"
#: ../../c-api/module.rst:408
msgid ""
"Most uses of this function should be using :c:func:`PyModule_FromDefAndSpec`"
" instead; only use this if you are sure you need it."
msgstr "大多数时候应该使用 :c:func:`PyModule_FromDefAndSpec` 代替使用此函数,除非你确定需要使用它。"
#: ../../c-api/module.rst:415
msgid "Process any execution slots (:c:data:`Py_mod_exec`) given in *def*."
msgstr "执行参数*def*中给出的任意执行槽(:c:data:`Py_mod_exec`)。"
#: ../../c-api/module.rst:421
msgid ""
"Set the docstring for *module* to *docstring*. This function is called "
"automatically when creating a module from ``PyModuleDef``, using either "
"``PyModule_Create`` or ``PyModule_FromDefAndSpec``."
msgstr ""
"将*module*的文档字符串设置为*docstring*。当使用 ``PyModule_Create`` 或 "
"``PyModule_FromDefAndSpec`` 从 ``PyModuleDef`` 创建模块时,会自动调用此函数。"
#: ../../c-api/module.rst:430
msgid ""
"Add the functions from the ``NULL`` terminated *functions* array to "
"*module*. Refer to the :c:type:`PyMethodDef` documentation for details on "
"individual entries (due to the lack of a shared module namespace, module "
"level \"functions\" implemented in C typically receive the module as their "
"first parameter, making them similar to instance methods on Python classes)."
" This function is called automatically when creating a module from "
"``PyModuleDef``, using either ``PyModule_Create`` or "
"``PyModule_FromDefAndSpec``."
msgstr ""
"将以 ``NULL`` 结尾的*functions*数组中的函数添加到*module*模块中。有关单个条目的更多细节,请参与 "
":c:type:`PyMethodDef` "
"文档(由于缺少共享的模块命名空间,在C中实现的模块级“函数”通常将模块作为它的第一个参数,与Python类的实例方法类似)。当使用 "
"``PyModule_Create`` 或 ``PyModule_FromDefAndSpec`` 从 ``PyModuleDef`` "
"创建模块时,会自动调用此函数。"
#: ../../c-api/module.rst:442
msgid "Support functions"
msgstr "支持函数"
#: ../../c-api/module.rst:444
msgid ""
"The module initialization function (if using single phase initialization) or"
" a function called from a module execution slot (if using multi-phase "
"initialization), can use the following functions to help initialize the "
"module state:"
msgstr "模块初始化函数(单阶段初始化)或通过模块的执行槽位调用的函数(多阶段初始化),可以使用以下函数,来帮助初始化模块的状态:"
#: ../../c-api/module.rst:451
msgid ""
"Add an object to *module* as *name*. This is a convenience function which "
"can be used from the module's initialization function."
msgstr "将一个名称为*name*的对象添加到*module*模块中。这是一个方便的函数,可以在模块的初始化函数中使用。"
#: ../../c-api/module.rst:454
msgid ""
"On success, return ``0``. On error, raise an exception and return ``-1``."
msgstr "如果成功,返回 ``0``。如果发生错误,引发异常并返回 ``-1``。"
#: ../../c-api/module.rst:456
msgid ""
"Return ``NULL`` if *value* is ``NULL``. It must be called with an exception "
"raised in this case."
msgstr "如果*value*为 ``NULL``,返回 ``NULL``。在调用它时发生这种情况,必须抛出异常。"
#: ../../c-api/module.rst:459 ../../c-api/module.rst:508
msgid "Example usage::"
msgstr "用法示例::"
#: ../../c-api/module.rst:473 ../../c-api/module.rst:526
msgid ""
"The example can also be written without checking explicitly if *obj* is "
"``NULL``::"
msgstr "这个例子也可以写成不显式地检查 *obj* 是否为 ``NULL``::"
#: ../../c-api/module.rst:485 ../../c-api/module.rst:542
msgid ""
"Note that ``Py_XDECREF()`` should be used instead of ``Py_DECREF()`` in this"
" case, since *obj* can be ``NULL``."
msgstr ""
"注意在此情况下应当使用 ``Py_XDECREF()`` 而不是 ``Py_DECREF()``,因为 *obj* 可能为 ``NULL``。"
#: ../../c-api/module.rst:493
msgid ""
"Similar to :c:func:`PyModule_AddObjectRef`, but steals a reference to "
"*value* on success (if it returns ``0``)."
msgstr ""
"类似于 :c:func:`PyModule_AddObjectRef`,但会在成功时偷取一个对 *value* 的引用(如果它返回 ``0`` 值)。"
#: ../../c-api/module.rst:496
msgid ""
"The new :c:func:`PyModule_AddObjectRef` function is recommended, since it is"
" easy to introduce reference leaks by misusing the "
":c:func:`PyModule_AddObject` function."
msgstr ""
"推荐使用新的 :c:func:`PyModule_AddObjectRef` 函数,因为误用 :c:func:`PyModule_AddObject` "
"函数很容易导致引用泄漏。"
#: ../../c-api/module.rst:502
msgid ""
"Unlike other functions that steal references, ``PyModule_AddObject()`` only "
"releases the reference to *value* **on success**."
msgstr "与其他窃取引用的函数不同,``PyModule_AddObject()`` 只在 **成功** 时释放对 *value* 的引用。"
#: ../../c-api/module.rst:505
msgid ""
"This means that its return value must be checked, and calling code must "
":c:func:`Py_DECREF` *value* manually on error."
msgstr "这意味着必须检查它的返回值,调用方必须在发生错误时手动为*value*调用 :c:func:`Py_DECREF`。"
#: ../../c-api/module.rst:548
msgid ""
"Add an integer constant to *module* as *name*. This convenience function "
"can be used from the module's initialization function. Return ``-1`` on "
"error, ``0`` on success."
msgstr ""
"将一个名称为*name*的整型常量添加到*module*模块中。这个方便的函数可以在模块的初始化函数中使用。如果发生错误,返回 ``-1``,成功返回 "
"``0``。"
#: ../../c-api/module.rst:555
msgid ""
"Add a string constant to *module* as *name*. This convenience function can "
"be used from the module's initialization function. The string *value* must "
"be ``NULL``-terminated. Return ``-1`` on error, ``0`` on success."
msgstr ""
"将一个名称为*name*的字符串常量添加到*module*模块中。这个方便的函数可以在模块的初始化函数中使用。字符串*value*必须以 "
"``NULL`` 结尾。如果发生错误,返回 ``-1`` ,成功返回 ``0`` 。"
#: ../../c-api/module.rst:562
msgid ""
"Add an int constant to *module*. The name and the value are taken from "
"*macro*. For example ``PyModule_AddIntMacro(module, AF_INET)`` adds the int "
"constant *AF_INET* with the value of *AF_INET* to *module*. Return ``-1`` on"
" error, ``0`` on success."
msgstr ""
"将一个整型常量添加到*module*模块中。名称和值取自*macro*参数。例如, ``PyModule_AddIntMacro(module, "
"AF_INET)`` 将值为*AF_INET*的整型常量*AF_INET*添加到*module*模块中。如果发生错误,返回 ``-1`` ,成功返回 "
"``0`` 。"
#: ../../c-api/module.rst:570
msgid "Add a string constant to *module*."
msgstr "将一个字符串常量添加到*module*模块中。"
#: ../../c-api/module.rst:574
msgid ""
"Add a type object to *module*. The type object is finalized by calling "
"internally :c:func:`PyType_Ready`. The name of the type object is taken from"
" the last component of :c:member:`~PyTypeObject.tp_name` after dot. Return "
"``-1`` on error, ``0`` on success."
msgstr ""
"将一个类型对象添加到 *module* 模块中。类型对象通过在函数内部调用 :c:func:`PyType_Ready` 完成初始化。类型对象的名称取自"
" :c:member:`~PyTypeObject.tp_name` 最后一个点号之后的部分。如果发生错误,返回 ``-1``,成功返回 ``0``。"
#: ../../c-api/module.rst:584
msgid "Module lookup"
msgstr "查找模块"
#: ../../c-api/module.rst:586
msgid ""
"Single-phase initialization creates singleton modules that can be looked up "
"in the context of the current interpreter. This allows the module object to "
"be retrieved later with only a reference to the module definition."
msgstr "单阶段初始化创建可以在当前解释器上下文中被查找的单例模块。这使得仅通过模块定义的引用,就可以检索模块对象。"
#: ../../c-api/module.rst:590
msgid ""
"These functions will not work on modules created using multi-phase "
"initialization, since multiple such modules can be created from a single "
"definition."
msgstr "这些函数不适用于通过多阶段初始化创建的模块,因为可以从一个模块定义创建多个模块对象。"
#: ../../c-api/module.rst:595
msgid ""
"Returns the module object that was created from *def* for the current "
"interpreter. This method requires that the module object has been attached "
"to the interpreter state with :c:func:`PyState_AddModule` beforehand. In "
"case the corresponding module object is not found or has not been attached "
"to the interpreter state yet, it returns ``NULL``."
msgstr ""
"返回当前解释器中由 *def* 创建的模块对象。此方法要求模块对象此前已通过 :c:func:`PyState_AddModule` "
"函数附加到解释器状态中。如果找不到相应的模块对象,或模块对象还未附加到解释器状态,返回 ``NULL``。"
#: ../../c-api/module.rst:602
msgid ""
"Attaches the module object passed to the function to the interpreter state. "
"This allows the module object to be accessible via "
":c:func:`PyState_FindModule`."
msgstr "将传给函数的模块对象附加到解释器状态。 这将允许通过 :c:func:`PyState_FindModule` 来访问该模块对象。"
#: ../../c-api/module.rst:605
msgid "Only effective on modules created using single-phase initialization."
msgstr "仅在使用单阶段初始化创建的模块上有效。"
#: ../../c-api/module.rst:607
msgid ""
"Python calls ``PyState_AddModule`` automatically after importing a module, "
"so it is unnecessary (but harmless) to call it from module initialization "
"code. An explicit call is needed only if the module's own init code "
"subsequently calls ``PyState_FindModule``. The function is mainly intended "
"for implementing alternative import mechanisms (either by calling it "
"directly, or by referring to its implementation for details of the required "
"state updates)."
msgstr ""
"Python 会在导入一个模块后自动调用 ``PyState_AddModule``,因此从模块初始化代码中调用它是没有必要的(但也没有害处)。 "
"显式的调用仅在模块自己的初始化代码后继调用了 ``PyState_FindModule`` 的情况下才是必要的。 "
"此函数主要是为了实现替代导入机制(或是通过直接调用它,或是通过引用它的实现来获取所需的状态更新详情)。"
#: ../../c-api/module.rst:615 ../../c-api/module.rst:626
msgid "The caller must hold the GIL."
msgstr "调用时必须携带GIL。"
#: ../../c-api/module.rst:617
msgid "Return 0 on success or -1 on failure."
msgstr "成功是返回 0 或者失败时返回 -1。"
#: ../../c-api/module.rst:623
msgid ""
"Removes the module object created from *def* from the interpreter state. "
"Return 0 on success or -1 on failure."
msgstr "从解释器状态中移除由 *def* 创建的模块对象。 成功时返回 0,者失败时返回 -1。"
#: ../../c-api/module.rst:8
msgid "object"
msgstr "object -- 对象"
#: ../../c-api/module.rst:8
msgid "module"
msgstr "module"
#: ../../c-api/module.rst:13
msgid "ModuleType (in module types)"
msgstr "ModuleType (在 types 模块中)"
#: ../../c-api/module.rst:33 ../../c-api/module.rst:74
msgid "__name__ (module attribute)"
msgstr "__name__ (模块属性)"
#: ../../c-api/module.rst:33
msgid "__doc__ (module attribute)"
msgstr "__doc__ (模块属性)"
#: ../../c-api/module.rst:33 ../../c-api/module.rst:104
msgid "__file__ (module attribute)"
msgstr "__file__ (模块属性)"
#: ../../c-api/module.rst:33
msgid "__package__ (module attribute)"
msgstr "__package__ (模块属性)"
#: ../../c-api/module.rst:33
msgid "__loader__ (module attribute)"
msgstr "__loader__ (模块属性)"
#: ../../c-api/module.rst:60
msgid "__dict__ (module attribute)"
msgstr "__dict__ (模块属性)"
#: ../../c-api/module.rst:74 ../../c-api/module.rst:104
msgid "SystemError (built-in exception)"
msgstr "SystemError (内置异常)"