If a field in a CSV file begins with an apostrophe ('
), both Excel and Numbers will treat the field as text, and not render it with any numerical formatting.
Your CSV files appear to try to force text rendering through enclosing number fields in double quotes, but Numbers and Excel don't seem to take the hint that double quote numbers should be treated as strings. The trick seems to be to modify the CSV files so they use the "starts with a single apostrophe" trick rather than the "contained in double quotes" trick for numeric fields, but keep the double quotes for text fields involving punctuation (including commas, quotation marks, line breaks, etc).
To process your CSV files so they do this, you can create an Automator application.
In Automator, create a new Application.
It will have a single action: Run Shell Script (passing input as arguments). Here is the script:
for f in "$@"
do
perl -pi -e "s/\"\"([0-9A-Za-z: \.\-+]+)\"/'\1/g" "$f"
done
Save the resulting application on your Desktop. Drop any CSV files you want to use in Numbers on the application icon, and they will be converted so Numbers should keep the numbers in the fields as literal numbers, and not format them or throw away information.
Back up your data before trying this; it is possible that a particularly oddly constructed string in a record field could throw off the results here.
Long text when Wrap text in cell is turned off does not merge with the next cell, it simply overlays on top of the adjacent cell if the adjacent cell is empty. Numbers just hides the borders for readability. If the adjacent cell has content, the text hides behind it.
There is no way, unfortunately, to expand the width of the cell to fit without expanding the width of the entire column.
Experiment with the text wrapping to get your desired result.
Hope this is useful!
Best Answer
After @nohillside's reply, apparently there is the built-in CURRENCY function in Numbers that can do exactly what I was describing in my question.