<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                # 6.6.?全部放在一起 再一次,所有的多米諾骨牌都放好了。我們已經看過每行代碼是如何工作的了。現在往回走一步,看一下放在一起是怎么樣的。 ## 例?6.21.?`listDirectory` ``` def listDirectory(directory, fileExtList): "get list of file info objects for files of particular extensions" fileList = [os.path.normcase(f) for f in os.listdir(directory)] fileList = [os.path.join(directory, f) for f in fileList if os.path.splitext(f)[1] in fileExtList] def getFileInfoClass(filename, module=sys.modules[FileInfo.__module__]): "get file info class from filename extension" subclass = "%sFileInfo" % os.path.splitext(filename)[1].upper()[1:] return hasattr(module, subclass) and getattr(module, subclass) or FileInfo return [getFileInfoClass(f)(f) for f in fileList] ``` | | | | --- | --- | | \[1\] | `listDirectory` 是整個模塊主要的有趣之處。它接收一個 dictionary (在我的例子中如 `c:\music\_singles\`) 和一個感興趣的文件擴展名列表 (如 `['.mp3']`),接著它返回一個類實例的 list ,這些類實例的行為像 dictionary,包含了在目錄中每個感興趣文件的元數據。并且實現起來只用了幾行直觀的代碼。 | | \[2\] | 正如在[前一節](os_module.html "6.5.?與目錄共事")我們所看到的,這行代碼得到一個全路徑名的列表,它的元素是在 `directory` 中有著我們感興趣的文件后綴 (由 `fileExtList` 所指定的) 的所有文件的路徑名。 | | \[3\] | 老學校出身的 Pascal 程序員可能對嵌套函數感到熟悉,但大部分人,當我告訴他們 Python 支持嵌套函數時,都茫然地看著我。_嵌套函數_,從字面理解,是定義在函數內的函數。嵌套函數 `getFileInfoClass` 只能在定義它的函數 `listDirectory` 內進行調用。正如任何其它的函數一樣,不需要一個接口聲明或奇怪的什么東西,只要定義函數,開始編碼就行了。 | | \[4\] | 既然你已經看過 [`os`](os_module.html "6.5.?與目錄共事") 模塊了,這一行應該能理解了。它得到文件的擴展名 (`os.path.splitext(filename)[1]`),將其轉換為大寫字母 (`.upper()`),從圓點處進行分片 (`[1:]`),使用字符串格式化從其中生成一個類名。所以 `c:\music\ap\mahadeva.mp3` 變成 `.mp3` 再變成 `MP3` 再變成 `MP3FileInfo`。 | | \[5\] | 在生成完處理這個文件的處理類的名字之后,我們查閱在這個模塊中是否存在這個處理類。如果存在,我們返回這個類,否則我們返回基類 `FileInfo`。這一點很重要:_這個函數返回一個類_。不是類的實例,而是類本身。 | | \[6\] | 對每個屬于我們 “感興趣文件” 列表 (`fileList`)中的文件,我們用文件名 (`f`) 來調用 `getFileInfoClass`。調用 `getFileInfoClass(f)` 返回一個類;我們并不知道確切是哪一個類,但是我們并不關心。接著我們創建這個類 (不管它是什么) 的一個實例,傳入文件名 (又是 `f`) 給 `__init__` 方法。正如我們在[本章的前面](../object_oriented_framework/special_class_methods.html#fileinfo.specialmethods.setname "例?5.15.?設置 MP3FileInfo 的 name")所看到的,`FileInfo` 的 `__init__` 方法設置了 `self["name"]`,它將引發 `__setitem__` 的調用,而 `__setitem__` 在子類 (`MP3FileInfo`) 中被覆蓋掉了,用來適當地對文件進行分析,取出文件的元數據。我們對所有感興趣的文件進行處理,返回結果實例的一個 list。 | 請注意 `listDirectory` 完全是通用的。它事先不知道將得到哪種類型的文件,也不知道哪些定義好的類能夠處理這些文件。它檢查目錄中要進行處理的文件,然后反觀本身模塊,了解定義了什么特別的處理類 (像 `MP3FileInfo`)。你可以對這個程序進行擴充,對其它類型的文件進行處理,只要用適合的名字定義類:`HTMLFileInfo` 用于 HTML 文件,`DOCFileInfo` 用于 Word `.doc` 文件,等等。不需要改動函數本身, `listDirectory` 將會對它們都進行處理,將工作交給適當的類,接著收集結果。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看