ความแตกต่างระหว่างโหมด a, a +, w, w + และ r + ในฟังก์ชั่น open-in หรือไม่?


608

ในหลามในตัวเปิดฟังก์ชั่นสิ่งที่เป็นความแตกต่างที่แน่นอนระหว่างโหมดw, a, w+, a+และr+?

โดยเฉพาะเอกสารหมายถึงสิ่งเหล่านี้ทั้งหมดจะอนุญาตให้เขียนไฟล์และบอกว่าจะเปิดไฟล์สำหรับ "ผนวก", "เขียน" และ "อัปเดต" โดยเฉพาะ แต่ไม่ได้กำหนดความหมายของคำเหล่านี้


11
ลิงก์ที่คุณระบุจะกำหนดค่าอย่างแน่นอน ส่วนใดเกี่ยวกับลิงค์ที่คุณให้คุณไม่เห็นหรือเข้าใจ? คุณช่วยอธิบายคำถามของคุณเพื่ออธิบายสิ่งที่คุณไม่เข้าใจเกี่ยวกับลิงค์ได้หรือไม่?
S.Lott

@ChrisB - ฉันรายงานสิ่งนี้ว่าเป็นข้อผิดพลาดที่bugs.python.org/issue19627
Bulwersator

2
ไม่มีเอกสารง่ายๆและแบบเดียวที่อธิบายความหมายของเครื่องหมาย +?
Charlie Parker

คำตอบ:


740

fopen()โหมดการเปิดเป็นเหมือนกับเหล่านั้นสำหรับฟังก์ชั่นมาตรฐานห้องสมุด C

BSD fopenmanpageกำหนดไว้ดังนี้:

 The argument mode points to a string beginning with one of the following
 sequences (Additional characters may follow these sequences.):

 ``r''   Open text file for reading.  The stream is positioned at the
         beginning of the file.

 ``r+''  Open for reading and writing.  The stream is positioned at the
         beginning of the file.

 ``w''   Truncate file to zero length or create text file for writing.
         The stream is positioned at the beginning of the file.

 ``w+''  Open for reading and writing.  The file is created if it does not
         exist, otherwise it is truncated.  The stream is positioned at
         the beginning of the file.

 ``a''   Open for writing.  The file is created if it does not exist.  The
         stream is positioned at the end of the file.  Subsequent writes
         to the file will always end up at the then current end of file,
         irrespective of any intervening fseek(3) or similar.

 ``a+''  Open for reading and writing.  The file is created if it does not
         exist.  The stream is positioned at the end of the file.  Subse-
         quent writes to the file will always end up at the then current
         end of file, irrespective of any intervening fseek(3) or similar.

3
ผมเชื่อว่าคุณหมายถึงการเรียก fopen ในห้องสมุดมาตรฐาน C (ซึ่งไม่ได้โทรระบบ)
เอลี Courtwright

14
หมายเหตุ: Python v3 เพิ่มจำนวนโหมดเพิ่มเติม ลิงก์ไปยัง docs
Alex

5
สังเกตว่าwและw+ทั้งสองสามารถทำได้The file is created if it does not exist
Wei Yang

4
บน Windows, bผนวกเข้ากับโหมดการเปิดไฟล์ในโหมดไบนารีดังนั้นยังมีโหมดเช่นrb, และwb r+bPython บน Windows สร้างความแตกต่างระหว่างข้อความและไฟล์ไบนารี อักขระสิ้นสุดบรรทัดในไฟล์ข้อความจะเปลี่ยนแปลงโดยอัตโนมัติเล็กน้อยเมื่อมีการอ่านหรือเขียนข้อมูล

6
ฉันสิทธิที่จะบอกว่า+ไม่ได้ทำบางสิ่งบางอย่างที่เป็นอิสระที่สอดคล้องกันถ้ามันเป็นa, wหรือr? หรือฉันไม่เห็นรูปแบบ? รูปแบบคืออะไร?
Charlie Parker

509

ฉันสังเกตเห็นว่าทุกครั้งที่ฉันต้องเปิด Google อีกครั้งเพื่อสร้างภาพจิตว่าอะไรคือความแตกต่างหลักระหว่างโหมด ดังนั้นฉันคิดว่าแผนภาพจะอ่านได้เร็วขึ้นในครั้งต่อไป บางทีคนอื่นอาจเห็นว่ามีประโยชน์เช่นกัน


3
aคำอธิบายที่ไม่ถูกต้อง การเขียนจะอยู่ในตำแหน่งที่ท้ายเสมอ
Antti Haapala

10
@ และฉันเชื่อว่า @Antti หมายถึงสถานSubsequent writes to the file will always end up at the then current end of file, irrespective of any intervening fseek(3) or similarที่ซึ่งค่อนข้างแข็งแกร่งกว่าเพียงแค่บอกว่าตำแหน่งเริ่มต้นคือจุดจบ
jcai

8
@ CharlieParker มีสองการดำเนินงานของไฟล์ (อ่านเขียน) โหมดRเป็นหลักสำหรับการอ่านโหมดW , เป็นหลักสำหรับการเขียน และเครื่องหมายบวกช่วยให้การดำเนินการที่สองสำหรับโหมดที่กำหนด (กล่าวง่ายๆ)
Jeyekomon

22
สำหรับคนรุ่นหลัง: truncate หมายถึงการเขียนทับตั้งแต่ต้น
Minh Tran

4
@Jeyekomon สรุปของคุณในความคิดเห็นของคุณที่นี่น่าจะเป็นสิ่งเดียวที่มีประโยชน์ที่สุดที่ฉันได้อ่านในการพยายามที่จะทำให้หัวของฉันไปรอบ ๆ โหมดเหล่านี้ในแบบที่ฉันจำได้ตอนนี้! แผนภูมิการไหลในคำตอบนี้มีความสวยงามและตารางในคำตอบด้านล่างนั้นยอดเยี่ยม แต่ถ้าคำตอบเหล่านี้ (และที่อื่น ๆ ) เริ่มต้นด้วยจุดง่าย ๆ นี้และทำงานจากที่นั่นมันจะช่วยให้กรอบจิตที่ดีขึ้นมาก บน. ขอบคุณมาก (ฉันรู้ว่านี่อาจจะเป็นขอบเขตของสแปม แต่ฉันรู้สึกว่าความคิดเห็นของคุณสมควรได้รับการยอมรับ)
ทิม

206

ข้อมูลเดียวกันเพียงในรูปแบบตาราง

                  | r   r+   w   w+   a   a+
------------------|--------------------------
read              | +   +        +        +
write             |     +    +   +    +   +
write after seek  |     +    +   +
create            |          +   +    +   +
truncate          |          +   +
position at start | +   +    +   +
position at end   |                   +   +

ความหมายคือ: (เพื่อหลีกเลี่ยงการตีความผิด ๆ )

  • อนุญาตให้อ่าน - อ่านจากไฟล์ได้
  • อนุญาตให้เขียน - เขียนไปยังไฟล์ได้

  • สร้าง - ไฟล์ถูกสร้างขึ้นหากยังไม่มีอยู่

  • trunctate - ในระหว่างการเปิดไฟล์มันจะว่างเปล่า (เนื้อหาทั้งหมดของไฟล์จะถูกลบ)

  • position at start - หลังจากเปิดไฟล์แล้วตำแหน่งเริ่มต้นจะถูกตั้งไว้ที่จุดเริ่มต้นของไฟล์

  • position at end - หลังจากเปิดไฟล์แล้วตำแหน่งเริ่มต้นจะถูกตั้งไว้ที่ท้ายไฟล์

หมายเหตุ: aและa+ต่อท้ายไฟล์เสมอ - ละเว้นseekการเคลื่อนไหวใด ๆ
BTW พฤติกรรมที่น่าสนใจอย่างน้อยใน win7 / python2.7 ของฉันสำหรับไฟล์ใหม่ที่เปิดในa+โหมด:
write('aa'); seek(0, 0); read(1); write('b')- ที่สองwriteถูกละเว้น
write('aa'); seek(0, 0); read(2); write('b')- ที่สองwriteเพิ่มขึ้นIOError


10
เหตุใดจึงไม่มี "สร้างไฟล์หากไม่มีอยู่หากมีอยู่ให้วางตำแหน่งเริ่มต้นเปิดใช้งานการอ่านและเขียน"? นี่คือกรณีการใช้งานที่ชัดเจนที่สุดสำหรับฉัน: ฉันกำลังจัดเก็บข้อมูลไว้ในไฟล์ หากไฟล์ไม่ได้อยู่ที่นั่นให้สร้างมันแทนการผิดพลาด หากมีข้อมูลในไฟล์ที่ฉันต้องการอ่านจากด้านบนให้อัปเดตบางอย่างจากนั้นเขียนไฟล์ใหม่อีกครั้งจาก 0 เป็นเวลาถัดไปที่ฉันโหลด ฉันใช้open(file,'a'); close(); open(file,'r+')เพื่อทำสิ่งนี้ให้สำเร็จ
pinhead

2
"การตัดทอน" หมายถึงอะไรในบริบทนี้
Charlie Parker

3
@CharlieParker หมายความว่าเนื้อหาทั้งหมดของไฟล์ถูกลบ (ไฟล์ว่างเปล่า)
industryworker3595112

1
คุณอาจต้องการที่จะเพิ่มทราบว่ามีaและa+เขียนจะเสมอseek()เกิดขึ้นที่จุดสิ้นสุดของแฟ้มโดยไม่คำนึงถึงว่าหนึ่งด้วยตนเองย้ายตัวชี้ใช้
balu

1
สิ่งที่เกี่ยวกับการปรับปรุงตารางเพื่อรวม 'x' สำหรับ Python 3
Nikos Alexandris

39

ตัวเลือกเหมือนกับฟังก์ชั่น fopenในไลบรารีมาตรฐาน C:

w ตัดทอนไฟล์เขียนทับสิ่งที่มีอยู่แล้ว

a ต่อท้ายไฟล์เพิ่มลงในสิ่งที่มีอยู่แล้ว

w+ เปิดสำหรับการอ่านและการเขียนการตัดทอนไฟล์ แต่ยังช่วยให้คุณสามารถอ่านสิ่งที่เขียนลงในไฟล์ได้

a+ เปิดสำหรับการต่อท้ายและการอ่านช่วยให้คุณทั้งสองต่อท้ายไฟล์และอ่านเนื้อหา


2
"การตัดทอน" หมายถึงอะไรในบริบทนี้ การลบข้อมูลเก่าถ้ามีหรือไม่ หรืออย่างอื่นที่เฉพาะเจาะจงมากขึ้น?
Charlie Parker

3
@CharlieParker: ถูกต้อง - หมายความว่าข้อมูลทั้งหมดในไฟล์ที่มีอยู่จะถูกดร็อปและเราเริ่มเขียนตั้งแต่ต้นไฟล์ที่ว่างตอนนี้
Eli Courtwright

9

ฉันคิดว่านี่เป็นสิ่งสำคัญที่ต้องพิจารณาสำหรับการดำเนินการข้ามแพลตฟอร์มเช่นในฐานะ CYA :)

บน Windows 'b' ต่อท้ายโหมดจะเปิดไฟล์ในโหมดไบนารีดังนั้นจึงมีโหมดเช่น 'rb', 'wb' และ 'r + b' Python บน Windows สร้างความแตกต่างระหว่างข้อความและไฟล์ไบนารี อักขระสิ้นสุดบรรทัดในไฟล์ข้อความจะเปลี่ยนแปลงโดยอัตโนมัติเล็กน้อยเมื่อมีการอ่านหรือเขียนข้อมูล การปรับเปลี่ยนข้อมูลไฟล์หลังนี้เป็นเรื่องปกติสำหรับไฟล์ข้อความ ASCII แต่มันจะทำให้ข้อมูลไบนารีเสียหายเช่นนั้นในไฟล์ JPEG หรือ EXE ระมัดระวังในการใช้โหมดไบนารีเมื่ออ่านและเขียนไฟล์ดังกล่าว บน Unix ไม่ได้เป็นการยากที่จะผนวก 'b' เข้ากับโหมดดังนั้นคุณจึงสามารถใช้เป็นแพลตฟอร์มได้อย่างอิสระสำหรับไฟล์ไบนารีทั้งหมด

นี้จะยกมาโดยตรงจากงูหลามมูลนิธิซอฟต์แวร์ 2.7.x


9

ฉันกดปุ่มนี้เพื่อพยายามหาสาเหตุว่าทำไมคุณถึงใช้โหมด 'w +' กับ 'w' ในที่สุดฉันก็ทำการทดสอบ ฉันไม่เห็นวัตถุประสงค์มากสำหรับโหมด 'w +' ในทั้งสองกรณีไฟล์จะถูกตัดทอนเพื่อเริ่มต้นด้วย อย่างไรก็ตามด้วย 'w +' คุณสามารถอ่านได้หลังจากเขียนโดยการค้นหากลับ ถ้าคุณลองอ่านด้วย 'w' มันจะเพิ่ม IOError การอ่านโดยไม่ใช้การค้นหาด้วยโหมด 'w +' จะไม่เกิดผลใด ๆ เนื่องจากตัวชี้ไฟล์จะเป็นตำแหน่งที่คุณเขียน

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.