


A brief analysis of the role and usage of the yield keyword in Python
Foreword
In order to understand what yield is, you must first understand what a generator (generator
) is. Before talking about the generator, let’s talk about the iterator (iterator
). When creating a list (list
), you can one by one Reading each item, this is called iteration (iteration
).
>>> mylist = [1, 2, 3] >>> for i in mylist : ... print(i) 1 2 3
mylist
is an iterable object. When you use a list comprehension to create a list, you create an iterable object:
>>> mylist = [x*x for x in range(3)] >>> for i in mylist : ... print(i) 0 1 4
You can use "for... Make repeated reads. But you have to store all the elements in memory in advance, and when there are many elements in those objects, not every item will be useful to you.
The generator is also an iterable object, but you can only read it once, because it does not store all values in memory, it generates values dynamically:
>>> mygenerator = (x*x for x in range(3)) >>> for i in mygenerator : ... print(i) 0 1 4
It looks like there is no difference except replacing [] with (). However, you cannot use for i in mygenerator again, because the generator can only be iterated once: first it calculates 0, then continues to calculate 1, then calculates 4, one after another...
is a keyword similar to return
, except that this function returns a generator.
>>> def createGenerator() : ... mylist = range(3) ... for i in mylist : ... yield i*i ... >>> mygenerator = createGenerator() # create a generator >>> print(mygenerator) # mygenerator is an object! <generator object createGenerator at 0xb7555c34> >>> for i in mygenerator: ... print(i) 0 1 4
This example itself is meaningless, but it clearly illustrates that the function will return a set of values that can only be read once. To master yield, the first thing you must understand is: when you call the generator function, as in the above example
createGenerator() , the program does not execute the code in the function body, it just returns the generator object, which is quite subtle. The code inside the function body will not run until each loop iteration (for) of the generator.
keyword from the beginning, and then return the value after yield
as the return value of the first iteration. Then, each time this function is executed, it will continue to execute what you are doing The next time in the loop defined inside the function, the value is returned until there is nothing left to return.
If the yield
keyword is not defined inside the generator, then the generator is considered empty. This may happen because the loop is running out, or the if/else conditions are not met.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

An application that converts XML directly to PDF cannot be found because they are two fundamentally different formats. XML is used to store data, while PDF is used to display documents. To complete the transformation, you can use programming languages and libraries such as Python and ReportLab to parse XML data and generate PDF documents.

To convert XML images, you need to determine the XML data structure first, then select a suitable graphical library (such as Python's matplotlib) and method, select a visualization strategy based on the data structure, consider the data volume and image format, perform batch processing or use efficient libraries, and finally save it as PNG, JPEG, or SVG according to the needs.

There is no APP that can convert all XML files into PDFs because the XML structure is flexible and diverse. The core of XML to PDF is to convert the data structure into a page layout, which requires parsing XML and generating PDF. Common methods include parsing XML using Python libraries such as ElementTree and generating PDFs using ReportLab library. For complex XML, it may be necessary to use XSLT transformation structures. When optimizing performance, consider using multithreaded or multiprocesses and select the appropriate library.

The speed of mobile XML to PDF depends on the following factors: the complexity of XML structure. Mobile hardware configuration conversion method (library, algorithm) code quality optimization methods (select efficient libraries, optimize algorithms, cache data, and utilize multi-threading). Overall, there is no absolute answer and it needs to be optimized according to the specific situation.

Use most text editors to open XML files; if you need a more intuitive tree display, you can use an XML editor, such as Oxygen XML Editor or XMLSpy; if you process XML data in a program, you need to use a programming language (such as Python) and XML libraries (such as xml.etree.ElementTree) to parse.

XML beautification is essentially improving its readability, including reasonable indentation, line breaks and tag organization. The principle is to traverse the XML tree, add indentation according to the level, and handle empty tags and tags containing text. Python's xml.etree.ElementTree library provides a convenient pretty_xml() function that can implement the above beautification process.

It is impossible to complete XML to PDF conversion directly on your phone with a single application. It is necessary to use cloud services, which can be achieved through two steps: 1. Convert XML to PDF in the cloud, 2. Access or download the converted PDF file on the mobile phone.

To generate images through XML, you need to use graph libraries (such as Pillow and JFreeChart) as bridges to generate images based on metadata (size, color) in XML. The key to controlling the size of the image is to adjust the values of the <width> and <height> tags in XML. However, in practical applications, the complexity of XML structure, the fineness of graph drawing, the speed of image generation and memory consumption, and the selection of image formats all have an impact on the generated image size. Therefore, it is necessary to have a deep understanding of XML structure, proficient in the graphics library, and consider factors such as optimization algorithms and image format selection.
