<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>

                ??一站式輕松地調用各大LLM模型接口,支持GPT4、智譜、豆包、星火、月之暗面及文生圖、文生視頻 廣告
                # Python 文件I/O 本章只講述所有基本的 I/O 函數,更多函數請參考Python標準文檔。 ## 打印到屏幕 最簡單的輸出方法是用print語句,你可以給它傳遞零個或多個用逗號隔開的表達式。此函數把你傳遞的表達式轉換成一個字符串表達式,并將結果寫到標準輸出如下: ``` print "Python 是一個非常棒的語言,不是嗎?" ``` 你的標準屏幕上會產生以下結果: ~~~ Python 是一個非常棒的語言,不是嗎? ~~~ ## 讀取鍵盤輸入 Python提供了兩個內置函數從標準輸入讀入一行文本,默認的標準輸入是鍵盤。如下: * raw\_input * input ### raw\_input函數 raw\_input(\[prompt\]) 函數從標準輸入讀取一個行,并返回一個字符串(去掉結尾的換行符): ~~~ str = raw_input("請輸入:") print "你輸入的內容是: ", str ~~~ 這將提示你輸入任意字符串,然后在屏幕上顯示相同的字符串。當我輸入"Hello Python!",它的輸出如下: ~~~ 請輸入:Hello Python! 你輸入的內容是: Hello Python! ~~~ ### input函數 **input(\[prompt\])**函數和**raw\_input(\[prompt\])**函數基本類似,但是 input 可以接收一個Python表達式作為輸入,并將運算結果返回。 ~~~ #!/usr/bin/python # -*- coding: UTF-8 -*- str = input("請輸入:") print "你輸入的內容是: ", str ~~~ 這會產生如下的對應著輸入的結果: ~~~ 請輸入:[x*5 for x in range(2,10,2)] 你輸入的內容是: [10, 20, 30, 40] ~~~ ## 打開和關閉文件 現在,您已經可以向標準輸入和輸出進行讀寫。現在,來看看怎么讀寫實際的數據文件。 Python 提供了必要的函數和方法進行默認情況下的文件基本操作。你可以用**file**對象做大部分的文件操作。 ### open 函數 你必須先用Python內置的open()函數打開一個文件,創建一個file對象,相關的方法才可以調用它進行讀寫。 語法: ~~~ file object = open(file_name [, access_mode][, buffering]) ~~~ 各個參數的細節如下: * file\_name:file\_name變量是一個包含了你要訪問的文件名稱的字符串值。 * access\_mode:access\_mode決定了打開文件的模式:只讀,寫入,追加等。所有可取值見如下的完全列表。這個參數是非強制的,默認文件訪問模式為只讀(r)。 * buffering:如果buffering的值被設為0,就不會有寄存。如果buffering的值取1,訪問文件時會寄存行。如果將buffering的值設為大于1的整數,表明了這就是的寄存區的緩沖大小。如果取負值,寄存區的緩沖大小則為系統默認。 不同模式打開文件的完全列表: ![](https://img.kancloud.cn/3b/02/3b02881872e8136168147ca9545c4a74_835x594.png) ![](https://img.kancloud.cn/40/54/40548cd133e4e5daac881b6465832cc3_836x337.png) ![](https://img.kancloud.cn/61/b4/61b4d2d1656add9a095b933f37730418_836x271.png) ## File對象的屬性 一個文件被打開后,你有一個file對象,你可以得到有關該文件的各種信息。 以下是和file對象相關的所有屬性的列表: ![](https://img.kancloud.cn/ce/39/ce39706ee1a140bed9131248ce9ef06d_835x189.png) ## 打開一個文件 ~~~ fo = open("foo.txt", "w") print "文件名: ", fo.name print "是否已關閉 : ", fo.closed print "訪問模式 : ", fo.mode print "末尾是否強制加空格 : ", fo.softspace ~~~ 以上實例輸出結果: ~~~ 文件名: foo.txt 是否已關閉 : False 訪問模式 : w 末尾是否強制加空格 : 0 ~~~ ### close()方法 File 對象的 close()方法刷新緩沖區里任何還沒寫入的信息,并關閉該文件,這之后便不能再進行寫入。 當一個文件對象的引用被重新指定給另一個文件時,Python 會關閉之前的文件。用 close()方法關閉文件是一個很好的習慣。 語法: ~~~ fileObject.close() ~~~ 例子 ## 打開一個文件 ## 關閉打開的文件 ~~~ fo = open("foo.txt", "w") print "文件名: ", fo.name fo.close() ~~~ 以上實例輸出結果: ~~~ 文件名: foo.txt ~~~ 讀寫文件: file對象提供了一系列方法,能讓我們的文件訪問更輕松。來看看如何使用read()和write()方法來讀取和寫入文件。 ### write()方法 write()方法可將任何字符串寫入一個打開的文件。需要重點注意的是,Python字符串可以是二進制數據,而不是僅僅是文字。 write()方法不會在字符串的結尾添加換行符('\\n'): 語法: ~~~ fileObject.write(string) ~~~ 在這里,被傳遞的參數是要寫入到已打開文件的內容。 例子: ~~~ fo = open("foo.txt", "w") fo.write( "www.yingtai.com!\nVery good site!\n") fo.close() ~~~ 上述方法會創建foo.txt文件,并將收到的內容寫入該文件,并最終關閉文件。如果你打開這個文件,將看到以下內容: ~~~ $ cat foo.txt www.yingtai.com! Very good site! ~~~ ### read()方法 read()方法從一個打開的文件中讀取一個字符串。需要重點注意的是,Python字符串可以是二進制數據,而不是僅僅是文字。 語法: ~~~ fileObject.read([count]) ~~~ 在這里,被傳遞的參數是要從已打開文件中讀取的字節計數。該方法從文件的開頭開始讀入,如果沒有傳入count,它會嘗試盡可能多地讀取更多的內容,很可能是直到文件的末尾。 ### 例子: 這里我們用到以上創建的 foo.txt 文件。 ~~~ fo = open("foo.txt", "r+") str = fo.read(10) print "讀取的字符串是 : ", str fo.close() ~~~ 以上實例輸出結果: ~~~ 讀取的字符串是 : www.yingta ~~~ 文件位置: ## 文件定位 tell()方法告訴你文件內的當前位置, 換句話說,下一次的讀寫會發生在文件開頭這么多字節之后。 seek(offset \[,from\])方法改變當前文件的位置。Offset變量表示要移動的字節數。From變量指定開始移動字節的參考位置。 如果from被設為0,這意味著將文件的開頭作為移動字節的參考位置。如果設為1,則使用當前的位置作為參考位置。如果它被設為2,那么該文件的末尾將作為參考位置。 例子: 就用我們上面創建的文件foo.txt。 ~~~ # 打開一個文件 fo = open("foo.txt", "r+") str = fo.read(10) print "讀取的字符串是 : ", str # 查找當前位置 position = fo.tell() print "當前文件位置 : ", position # 把指針再次重新定位到文件開頭 position = fo.seek(0, 0) str = fo.read(10) print "重新讀取字符串 : ", str # 關閉打開的文件 fo.close() ~~~ 以上實例輸出結果: ~~~ 讀取的字符串是 : www.yingta 當前文件位置 : 10 重新讀取字符串 : www.yingta ~~~ ## 重命名和刪除文件 Python的os模塊提供了幫你執行文件處理操作的方法,比如重命名和刪除文件。 要使用這個模塊,你必須先導入它,然后才可以調用相關的各種功能。 rename()方法: rename()方法需要兩個參數,當前的文件名和新文件名。 語法: ~~~ os.rename(current_file_name, new_file_name) ~~~ 例子: 下例將重命名一個已經存在的文件test1.txt。 ~~~ import os # 重命名文件test1.txt到test2.txt。 os.rename( "test1.txt", "test2.txt" ) ~~~ ### remove()方法 你可以用remove()方法刪除文件,需要提供要刪除的文件名作為參數。 語法: ~~~ os.remove(file_name) ~~~ 例子: 下例將刪除一個已經存在的文件test2.txt。 ~~~ import os # 刪除一個已經存在的文件test2.txt os.remove("test2.txt") ~~~ ## Python里的目錄: 所有文件都包含在各個不同的目錄下,不過Python也能輕松處理。os模塊有許多方法能幫你創建,刪除和更改目錄。 ### mkdir()方法 可以使用os模塊的mkdir()方法在當前目錄下創建新的目錄們。你需要提供一個包含了要創建的目錄名稱的參數。 語法: ~~~ os.mkdir("newdir") ~~~ 例子: 下例將在當前目錄下創建一個新目錄test。 ~~~ import os # 創建目錄test os.mkdir("test") ~~~ ### chdir()方法 可以用chdir()方法來改變當前的目錄。chdir()方法需要的一個參數是你想設成當前目錄的目錄名稱。 語法: ~~~ os.chdir("newdir") ~~~ 例子: 下例將進入"/home/newdir"目錄。 ~~~ import os # 將當前目錄改為"/home/newdir" os.chdir("/home/newdir") ~~~ getcwd()方法: getcwd()方法顯示當前的工作目錄。 語法: ~~~ os.getcwd() ~~~ 例子: 下例給出當前目錄: ~~~ import os # 給出當前的目錄 print os.getcwd() ~~~ ### rmdir()方法 rmdir()方法刪除目錄,目錄名稱以參數傳遞。 在刪除這個目錄之前,它的所有內容應該先被清除。 語法: ~~~ os.rmdir('dirname') ~~~ 例子: 以下是刪除" /tmp/test"目錄的例子。目錄的完全合規的名稱必須被給出,否則會在當前目錄下搜索該目錄。 ~~~ import os # 刪除”/tmp/test”目錄 os.rmdir( "/tmp/test" ) ~~~ 遍歷目錄 ``` for root, dirs, files in os.walk("."): print('root') for name in files: print(name) ```
                  <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>

                              哎呀哎呀视频在线观看