Es bastante común que los programas GUI no puedan manejar archivos de texto grandes. Aunque 40 MB no suena como grande con respecto a los estándares actuales, pero eso puede aumentar mucho más en la memoria dependiendo de cómo se escriba la aplicación. Y las aplicaciones GUI a menudo no son las más eficientes.
Es posible que desee dividir el archivo de texto en varios más pequeños utilizando el terminal. Primero, verifique si puede abrir el archivo usando less filename.csv
en la Terminal, y si los caracteres se leen bien. De lo contrario, el archivo podría estar dañado y ese podría ser el problema.
Para la división aguda, intente usar algo como esto en la terminal:
#!/bin/bash
N=10000 # Number of lines per file
i=1
j=0
filename="hugefile.csv"
extension=.csv
while [ $i -le $(wc -l $filename|awk '{print $1}') ]
do
newfilename="$(basename $filename $extension)$j$extension"
echo $newfilename: $i
sed -n $i,$((i+$N))p $filename > $newfilename
j=$((j+1)); i=$((i+$N))
done
Copie y pegue eso en un documento de texto sin formato (por ejemplo, TextEdit en modo de texto sin formato o nano en la Terminal) y split.sh
asígnele un nombre o algo similar. Personalice los parámetros N
y filename
según sea necesario, por ejemplo, ingrese el número deseado de números por archivo N=...
y el nombre de archivo de su archivo fuente como filename="..."
. Esto generará la cantidad necesaria de archivos en su directorio actual para cubrir todas las líneas de los archivos de origen en archivos más pequeños de N
líneas cada uno. Los archivos tendrán un número añadido, por ejemplo, hugefile0.txt
a hugefile9.txt
o algo por el estilo.
Ahora debería poder abrir cada uno de estos archivos en su aplicación deseada. A menudo es deseable trabajar con porciones más pequeñas de un archivo grande que con todo el archivo a la vez. Incluso podría abrir los archivos CSV resultantes en Numbers uno tras otro y copiar las líneas de cada archivo en un documento grande de Numbers. De esa manera, el importador probablemente no se quedará en un archivo tan grande.
En caso de que obtenga algún error con respecto a sed
o awk
, eso es porque Mac sed
y awk
son diferentes a los normales sed
o awk
. En ese caso, es posible que deba instalar regularmente sed
y awk
desde algo como macports o homebrew.
wc -l FILE.csv
en la Terminal para verificar)? ¿Qué sucede si intentas abrirlo en Textedit?