मैं किसी फ़ाइल के लिए एक विशेष संख्या में नल बाइट्स कैसे जोड़ूं? [बन्द है]


26

मेरे पास एक स्क्रिप्ट है जो कुछ फ़ाइलों को लिखती है लेकिन मुझे उन्हें एक विशिष्ट आकार की आवश्यकता है। तो मैं सोच रहा था कि क्या मानक कमांड लाइन टूल्स (जैसे, से कॉपी करके /dev/zero) का उपयोग करके किसी फ़ाइल को एक विशिष्ट संख्या में नल बाइट्स जोड़ने का एक तरीका है ?


1
यह प्रश्न ऑफ़-टॉपिक प्रतीत होता है क्योंकि यह प्रोग्रामिंग के बारे में है, जो स्टैक ओवरफ़्लो में आता है ।
जेनी डी का कहना है कि मोनिका

oflag=appendआपके लिए काम करता है ?
मार्क के कोवान

@Mark K Cowan द्वारा एक टिप्पणी को स्पष्ट करने के लिए; उसका मतलब है ddआज्ञा।
अलेक्जेंडर पॉज़्निव

FYI करें ऐसा लगता है जैसे fallocateकिसी फ़ाइल में छेद डालने के लिए एक और ऑपेरियन है। superuser.com/a/1172904/111432
akostadinov

जवाबों:


41

truncateकी तुलना में बहुत तेज है dd। फ़ाइल को 10 बाइट के उपयोग से विकसित करने के लिए:

 truncate -s +10 file.txt 

2
यह बहुत तेज़ है क्योंकि यह एक विरल फ़ाइल उत्पन्न करेगा, जो कि आप ज्यादातर समय चाहते हैं - लेकिन यदि आप विरल फ़ाइल नहीं चाहते हैं, तो dd दृष्टिकोण काम करेगा।
डेबोर्ट

34

आप इसे भी आजमा सकते हैं

dd if=/dev/zero bs=1 count=NUMBER >> yourfile

यह / dev / शून्य से पढ़ेगा और अपनेfile NUMBER बाइट्स के लिए संलग्न करेगा।


7

नीचे केवल dd का उपयोग करके किसी फ़ाइल में 10MB जोड़ने का एक उदाहरण है।

[root@rhel ~]# cp /etc/motd ./test
[root@rhel ~]# hexdump -C test |tail -5
000003e0  0a 0a 3d 3d 3d 3d 3e 20  54 65 78 74 20 6f 66 20  |..====> Text of |
000003f0  74 68 69 73 20 6d 65 73  73 61 67 65 20 69 73 20  |this message is |
00000400  69 6e 20 2f 65 74 63 2f  6d 6f 74 64 20 3c 3d 3d  |in /etc/motd <==|
00000410  3d 3d 0a                                          |==.|
00000413

[root@rhel ~]# dd if=/dev/zero of=/root/test ibs=1M count=10 obs=1M oflag=append conv=notrunc
10+0 records in
10+0 records out
10485760 bytes (10 MB) copied, 0.0208541 s, 503 MB/s

[root@rhel ~]# hexdump -C test |tail -5
00000410  3d 3d 0a 00 00 00 00 00  00 00 00 00 00 00 00 00  |==..............|
00000420  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
*
00a00410  00 00 00                                          |...|
00a00413

5

मेरा पहला अनुमान होगा:

dd if=/dev/zero of=myfile bs=1 count=nb_of_bytes seek=$(stat -c%s myfile)

मूल रूप से, यह कमांड फाइल के अंत में dd को "गो" को बताता है और पहले / देव / शून्य से पढ़ी गई कुछ बाइट्स जोड़ता है।

सादर,


2
cat "your file" /dev/zero | head -c "total number of bytes"

या

head -c "number of bytes to add" /dev/zero >> "your_file"

और अधिक आसानी से आकार की गणना करने के लिए:

head -c $(( "total number of bytes" - $(stat -c "%s" "your_file") )) /dev/zero >> "your_file"

0

यदि आप अपनी फ़ाइल को नल बाइट्स के साथ char *रख रहे हैं, तो मेरा अनुमान है कि आप सी। में फ़ाइल में हेरफेर कर रहे हैं । यदि यह मामला है, तो आपको फ़ाइल को नल बाइट्स के साथ पैड करने की आवश्यकता नहीं हो सकती है, केवल अंत में एक शून्य बाइट जोड़कर। फ़ाइल और फिर इसे यादृच्छिक बाइट्स के साथ पैड करना पर्याप्त हो सकता है। इस स्थिति में, सी प्रोग्राम बलो बहुत कुशल होगा (केवल 2 डी पैरामीटर की तुलना में छोटी फ़ाइलों पर उपयोग किया जा सकता है, अन्यथा डेटा ओवरराइट किया जाएगा)। यह भी हो सकता है कि आप क्या चाहते हैं (नल बाइट्स के साथ पैडिंग) क्योंकि lseekफ़ंक्शन परिभाषा बताती है कि:

Lseek () फ़ंक्शन फ़ाइल को मौजूदा डेटा के अंत से परे फ़ाइल को सेट करने की अनुमति देगा। यदि इस बिंदु पर डेटा बाद में लिखा गया है, तो अंतर में डेटा की बाद की रीडिंग 0 के साथ बाइट्स लौटाएगी, जब तक कि डेटा वास्तव में अंतर में नहीं लिखा जाता है।

इस मामले में, 1 से कॉल lseekऔर writeहटाया जा सकता है। लेकिन परीक्षण आपके सिस्टम 1 पर किया जाना चाहिए ...

#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>

/* 1st parameter: a file name, 2nd parameter: a file size. */
int main(int argc, char ** args) {
   int nfd = open(args[1], O_WRONLY);
   lseek(nfd, 0, SEEK_END);
   write(nfd, "\0", 1);
   lseek(nfd, atoi(args[2]) - 1, SEEK_SET);
   write(nfd, "\0", 1);
   close(nfd);
   return 0;
}
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.