1

如何创建一个新列,并在 csv 文件上使用 Python 为每个相应的机场记录编写首字母缩略词?

我有一个机场的 csv 文件,我希望机场的名称采用首字母缩写形式,以便我可以更紧凑地在地图上显示它们,机场符号显示它是什么。

一个例子是这个示例列表:

[“布拉德利天空牧场”、“火岛机场”、“帕尔默市机场”]

进入这个:['BSR','FIA','PMA']

接下来,您将如何放置“。” 每个首字母缩略词之间的句点标点?

我想它会是+ "." +什么".".join

最后,如果有办法摆脱“机场”这个词,这样每个首字母缩写词都不以“A”结尾,那将是一个好处?

例如,诸如.strip“机场”之类的内容……但这不是主要目标。

下面的编号列表显示了我拥有的代码示例,但我没有一致的解决方案。所以请只选择有意义的,如果没有,我想学习更有效的语法!

[原始机场数据来自 ESRI Living Atlas。] 我有一个名为“NameAbbrev”的新字段/列,我想在其中写入首字母缩写词,但我在 ArcPro 中执行此操作,它本质上包含一个用于计算新的黑盒界面字段。

旁注:如果这与地图相关,为什么我要发布到 SO 而不是 GeoNet?请注意,我的目标是使用 python,而不是询问 ArcPy。我认为基本原理是基于 python 操作 csv 文件(而 ArcPy 将在要素类上操作,您必须使用 ESRI 指定的函数)。SO 接触到更广泛的 Python 专家受众。

1)到目前为止,我已经遇到了如何将字符串转换为首字母缩写词,这对单个字符串而不是列表非常有效: Creating acronyms in Python

acronym = "".join(word[0] for word in test.upper().split())

2)并尝试拆分列表中的项目,或者如何根据示例(不是我的)在 csv 文件上执行 readlines:属性错误:'list' object has no attribute 'split'

def getQuakeData():
filename = input("Please enter the quake file: ")
# Use with to make sure the file gets closed
with open(filename, "r") as readfile:
    # no need for readlines; the file is already an iterable of lines
    # also, using generator expressions means no extra copies
    types = (line.split(",") for line in readfile)
    # iterate tuples, instead of two separate iterables, so no need for zip
    xys = ((type[1], type[2]) for type in types)
    for x, y in xys:
        print(x,y)

getQuakeData()

3)此外,我已经能够使用 pandas 将机场名称列打印到列表中:

import pandas
colnames = ['OBJECTID', 'POLYGON_ID', 'POLYGON_NM', 'NM_LANGCD', 'FEAT_TYPE', 'DETAIL_CTY', 'FEAT_COD', 'NAME_FIX', 'ORIG_FID', 'NameAbbrev']
data = pandas.read_csv(r'C:\Users\...\AZ_Airports_table.csv', names=colnames)

names = data.NAME_FIX.tolist()
print(names)

#Here is a sample of the list of airport names/print result.
#If you want a sample to demo guidance you could use these names:
#['NAME_FIX', 'Bradley Sky Ranch', 'Fire Island Airport', 'Palmer Municipal Airport', 'Kodiak Airport', 'Nome Airport', 'Kenai Municipal Airport', 'Iliamna Airport', 'Sitka Airport', 'Wrangell Airport', 'Sand Point Airport', 'Unalaska Airport', 'Adak Airport', 'Homer Airport', 'Cold Bay Airport']

4)我过去也可以使用搜索光标和写入器,但我不知道如何准确应用这些方法。(不相关的例子):

with open(outCsv, 'wb') as ouputCsv:  
writer = csv.writer(outputCsv)  
writer.writerow(fields)  # writes header containing list of fields  
rows = arcpy.da.SearchCursor(fc, field_names=fields)  
for row in rows:  
    writer.writerow(row)  # writes fc contents to output csv  
del rows

5)所以,我有一些碎片,但我不知道如何将它们全部组合在一起,或者它们是否可以组合在一起。这是我的科学怪人怪物的解决方案,但它是错误的,因为它试图查看每一列!

def getAcronym():
filename = r'C:\Users\...\AZ_Airports_table.csv'
# Use with to make sure the file gets closed
with open(filename, "r") as readfile:
    # no need for readlines; the file is already an iterable of lines
    # also, using generator expressions means no extra copies
    airport = (line.split(",") for line in readfile)
    # iterate tuples, instead of two separate iterables, so no need for zip
    abbreviation = "".join(word[0] for word in airport.upper().split())
    # could also try    filter(str.isupper, line)
print(abbreviation)

getAcronym()

有没有更简单的方法来结合这些想法并获得我想要的首字母缩写词列?还是有替代方法?

4

3 回答 3

1

最短的答案

您可以使用 for 循环遍历列表中的每个字符串,然后可以将每个结果添加到新列表中。如果你愿意,它可以变成一个函数。

airports = ['Bradley Sky Ranch', 'Fire Island Airport', 'Palmer Municipal Airport']

air_acronyms = []
for airport in airports:
    words = airport.split()
    letters = [word[0] for word in words]
    air_acronyms.append(".".join(letters))

print(air_acronyms)

输出

['B.S.R', 'F.I.A', 'P.M.A']
于 2019-03-16T02:15:09.677 回答
1

这可以非常简单地使用列表推导str.join和来完成filter

>>> data = ['Bradley Sky Ranch', 'Fire Island Airport', 'Palmer Municipal Airport']
>>> ['.'.join(filter(str.isupper, name)) for name in data]
['B.S.R', 'F.I.A', 'P.M.A']
于 2019-03-16T02:20:43.370 回答
0

我不知道,实际上也没有正确理解你想要什么,但据我所知,你想用每个单词的第一个字符生成字符串列表首字母缩写词。那么我下面的带有几个循环的解决方案呢?您可以使用or或 python 的其他很酷的功能来进一步实现您想要的。如果我想念什么,请告诉我。list comprehensionfilter

input = ['Bradley Sky Ranch', 'Fire Island Airport', 'Palmer Municipal Airport']

output = []
for i in input:
    j =  i.split(' ')
    res = ''
    for k in j:
        res+= k[0] + '.'
    output.append(res)
print(output)  

输出:

['B.S.R.', 'F.I.A.', 'P.M.A.']
于 2019-03-16T02:03:52.307 回答